@hmcts/media-viewer 4.1.8-exui-2600-1 → 4.1.8-exui-2489
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/assets/sass/box-highlight.scss +0 -38
- package/esm2022/lib/annotations/annotation-set/annotation-create/box-highlight-create/box-highlight-create.component.mjs +19 -74
- package/esm2022/lib/annotations/annotation-set/annotation-create/highlight-create/highlight-create.service.mjs +4 -4
- package/esm2022/lib/annotations/annotation-set/annotation-view/annotation-view.component.mjs +3 -37
- package/esm2022/lib/annotations/annotation-set/annotation-view/rectangle/rectangle.component.mjs +3 -39
- package/esm2022/lib/annotations/annotation-set/metadata-layer/metadata-layer.component.mjs +3 -3
- package/esm2022/lib/annotations/annotations.module.mjs +3 -9
- package/esm2022/lib/store/actions/annotation.actions.mjs +2 -3
- package/esm2022/lib/store/effects/annotation.effects.mjs +3 -13
- package/esm2022/lib/viewers/pdf-viewer/pdf-viewer.component.mjs +28 -3
- package/fesm2022/hmcts-media-viewer.mjs +60 -545
- package/fesm2022/hmcts-media-viewer.mjs.map +1 -1
- package/lib/annotations/annotation-set/annotation-create/box-highlight-create/box-highlight-create.component.d.ts +2 -16
- package/lib/annotations/annotation-set/annotation-create/box-highlight-create/box-highlight-create.component.d.ts.map +1 -1
- package/lib/annotations/annotation-set/annotation-create/highlight-create/highlight-create.service.d.ts +1 -1
- package/lib/annotations/annotation-set/annotation-create/highlight-create/highlight-create.service.d.ts.map +1 -1
- package/lib/annotations/annotation-set/annotation-view/annotation-view.component.d.ts +2 -8
- package/lib/annotations/annotation-set/annotation-view/annotation-view.component.d.ts.map +1 -1
- package/lib/annotations/annotation-set/annotation-view/rectangle/rectangle.component.d.ts +1 -10
- package/lib/annotations/annotation-set/annotation-view/rectangle/rectangle.component.d.ts.map +1 -1
- package/lib/annotations/annotation-set/metadata-layer/metadata-layer.component.d.ts +1 -2
- package/lib/annotations/annotation-set/metadata-layer/metadata-layer.component.d.ts.map +1 -1
- package/lib/annotations/annotations.module.d.ts +11 -13
- package/lib/annotations/annotations.module.d.ts.map +1 -1
- package/lib/store/actions/annotation.actions.d.ts +1 -2
- package/lib/store/actions/annotation.actions.d.ts.map +1 -1
- package/lib/store/effects/annotation.effects.d.ts +0 -1
- package/lib/store/effects/annotation.effects.d.ts.map +1 -1
- package/lib/viewers/pdf-viewer/pdf-viewer.component.d.ts +1 -0
- package/lib/viewers/pdf-viewer/pdf-viewer.component.d.ts.map +1 -1
- package/package.json +1 -1
- package/esm2022/lib/annotations/annotation-set/annotation-create/box-highlight-create/keyboard-box-draw.directive.mjs +0 -258
- package/esm2022/lib/annotations/annotation-set/annotation-view/rectangle/keyboard-box-move.directive.mjs +0 -122
- package/lib/annotations/annotation-set/annotation-create/box-highlight-create/keyboard-box-draw.directive.d.ts +0 -59
- package/lib/annotations/annotation-set/annotation-create/box-highlight-create/keyboard-box-draw.directive.d.ts.map +0 -1
- package/lib/annotations/annotation-set/annotation-view/rectangle/keyboard-box-move.directive.d.ts +0 -27
- package/lib/annotations/annotation-set/annotation-view/rectangle/keyboard-box-move.directive.d.ts.map +0 -1
|
@@ -1,258 +0,0 @@
|
|
|
1
|
-
import { Directive, EventEmitter, HostListener, Input, Output } from '@angular/core';
|
|
2
|
-
import * as i0 from "@angular/core";
|
|
3
|
-
export class KeyboardBoxDrawDirective {
|
|
4
|
-
set enabled(value) {
|
|
5
|
-
const wasEnabled = this._enabled;
|
|
6
|
-
this._enabled = value;
|
|
7
|
-
if (value && !wasEnabled && KeyboardBoxDrawDirective.lastInteractionWasKeyboard && !this.showCursor) {
|
|
8
|
-
this.initializeCursorForKeyboard();
|
|
9
|
-
}
|
|
10
|
-
}
|
|
11
|
-
get enabled() {
|
|
12
|
-
return this._enabled;
|
|
13
|
-
}
|
|
14
|
-
static { this.lastInteractionWasKeyboard = false; }
|
|
15
|
-
constructor(elementRef) {
|
|
16
|
-
this.elementRef = elementRef;
|
|
17
|
-
this._enabled = false;
|
|
18
|
-
this.minBoxSize = 10;
|
|
19
|
-
this.incrementSmall = 1;
|
|
20
|
-
this.incrementMedium = 5;
|
|
21
|
-
this.incrementLarge = 10;
|
|
22
|
-
this.drawingStarted = new EventEmitter();
|
|
23
|
-
this.drawingUpdated = new EventEmitter();
|
|
24
|
-
this.drawingConfirmed = new EventEmitter();
|
|
25
|
-
this.drawingCancelled = new EventEmitter();
|
|
26
|
-
this.cursorPositionChanged = new EventEmitter();
|
|
27
|
-
this.isDrawing = false;
|
|
28
|
-
this.showCursor = false;
|
|
29
|
-
if (typeof window !== 'undefined') {
|
|
30
|
-
window.addEventListener('keydown', KeyboardBoxDrawDirective.onGlobalKeyDown, { capture: true });
|
|
31
|
-
window.addEventListener('mousedown', KeyboardBoxDrawDirective.onGlobalMouseDown, { capture: true });
|
|
32
|
-
}
|
|
33
|
-
}
|
|
34
|
-
static onGlobalKeyDown() {
|
|
35
|
-
KeyboardBoxDrawDirective.lastInteractionWasKeyboard = true;
|
|
36
|
-
}
|
|
37
|
-
static onGlobalMouseDown() {
|
|
38
|
-
KeyboardBoxDrawDirective.lastInteractionWasKeyboard = false;
|
|
39
|
-
}
|
|
40
|
-
ngOnDestroy() {
|
|
41
|
-
this.cleanup();
|
|
42
|
-
}
|
|
43
|
-
initializeCursorForKeyboard() {
|
|
44
|
-
if (this.enabled && !this.showCursor && !this.isDrawing) {
|
|
45
|
-
const rect = this.elementRef.nativeElement.getBoundingClientRect();
|
|
46
|
-
if (rect.width > 0 && rect.height > 0) {
|
|
47
|
-
this.cursorX = rect.width / 2;
|
|
48
|
-
this.cursorY = rect.height / 2;
|
|
49
|
-
this.showCursor = true;
|
|
50
|
-
this.emitCursorPosition();
|
|
51
|
-
}
|
|
52
|
-
}
|
|
53
|
-
}
|
|
54
|
-
onKeyDown(event) {
|
|
55
|
-
if (!this.enabled) {
|
|
56
|
-
return;
|
|
57
|
-
}
|
|
58
|
-
if (event.key === 'Enter') {
|
|
59
|
-
event.preventDefault();
|
|
60
|
-
event.stopPropagation();
|
|
61
|
-
if (!this.isDrawing) {
|
|
62
|
-
this.startDrawing();
|
|
63
|
-
}
|
|
64
|
-
else {
|
|
65
|
-
this.confirmDrawing();
|
|
66
|
-
}
|
|
67
|
-
return;
|
|
68
|
-
}
|
|
69
|
-
if (event.key === 'Escape') {
|
|
70
|
-
event.preventDefault();
|
|
71
|
-
event.stopPropagation();
|
|
72
|
-
if (this.isDrawing) {
|
|
73
|
-
this.cancelDrawing();
|
|
74
|
-
}
|
|
75
|
-
else if (this.showCursor) {
|
|
76
|
-
this.hideCursor();
|
|
77
|
-
}
|
|
78
|
-
return;
|
|
79
|
-
}
|
|
80
|
-
if (['ArrowUp', 'ArrowDown', 'ArrowLeft', 'ArrowRight'].includes(event.key)) {
|
|
81
|
-
event.preventDefault();
|
|
82
|
-
event.stopPropagation();
|
|
83
|
-
if (this.isDrawing) {
|
|
84
|
-
this.resizeBox(event);
|
|
85
|
-
}
|
|
86
|
-
else {
|
|
87
|
-
this.moveCursor(event);
|
|
88
|
-
}
|
|
89
|
-
}
|
|
90
|
-
}
|
|
91
|
-
onBlur() {
|
|
92
|
-
if (this.showCursor && !this.isDrawing) {
|
|
93
|
-
this.hideCursor();
|
|
94
|
-
}
|
|
95
|
-
}
|
|
96
|
-
moveCursor(event) {
|
|
97
|
-
const increment = event.shiftKey ? this.incrementLarge : this.incrementMedium;
|
|
98
|
-
if (!this.showCursor) {
|
|
99
|
-
const rect = this.elementRef.nativeElement.getBoundingClientRect();
|
|
100
|
-
this.cursorX = rect.width / 2;
|
|
101
|
-
this.cursorY = rect.height / 2;
|
|
102
|
-
this.showCursor = true;
|
|
103
|
-
this.emitCursorPosition();
|
|
104
|
-
return;
|
|
105
|
-
}
|
|
106
|
-
const rect = this.elementRef.nativeElement.getBoundingClientRect();
|
|
107
|
-
switch (event.key) {
|
|
108
|
-
case 'ArrowUp':
|
|
109
|
-
this.cursorY = Math.max(0, this.cursorY - increment);
|
|
110
|
-
break;
|
|
111
|
-
case 'ArrowDown':
|
|
112
|
-
this.cursorY = Math.min(rect.height, this.cursorY + increment);
|
|
113
|
-
break;
|
|
114
|
-
case 'ArrowLeft':
|
|
115
|
-
this.cursorX = Math.max(0, this.cursorX - increment);
|
|
116
|
-
break;
|
|
117
|
-
case 'ArrowRight':
|
|
118
|
-
this.cursorX = Math.min(rect.width, this.cursorX + increment);
|
|
119
|
-
break;
|
|
120
|
-
}
|
|
121
|
-
this.emitCursorPosition();
|
|
122
|
-
}
|
|
123
|
-
startDrawing() {
|
|
124
|
-
let startX;
|
|
125
|
-
let startY;
|
|
126
|
-
if (this.showCursor) {
|
|
127
|
-
startX = this.cursorX;
|
|
128
|
-
startY = this.cursorY;
|
|
129
|
-
this.showCursor = false;
|
|
130
|
-
this.emitCursorPosition();
|
|
131
|
-
}
|
|
132
|
-
else {
|
|
133
|
-
// default to center
|
|
134
|
-
const rect = this.elementRef.nativeElement.getBoundingClientRect();
|
|
135
|
-
startX = rect.width / 2;
|
|
136
|
-
startY = rect.height / 2;
|
|
137
|
-
}
|
|
138
|
-
this.isDrawing = true;
|
|
139
|
-
this.drawStartX = startX;
|
|
140
|
-
this.drawStartY = startY;
|
|
141
|
-
this.currentWidth = this.minBoxSize;
|
|
142
|
-
this.currentHeight = this.minBoxSize;
|
|
143
|
-
this.emitDrawingStarted();
|
|
144
|
-
}
|
|
145
|
-
resizeBox(event) {
|
|
146
|
-
const increment = event.shiftKey ? this.incrementLarge : this.incrementSmall;
|
|
147
|
-
const rect = this.elementRef.nativeElement.getBoundingClientRect();
|
|
148
|
-
switch (event.key) {
|
|
149
|
-
case 'ArrowRight':
|
|
150
|
-
const maxWidth = rect.width - this.drawStartX;
|
|
151
|
-
this.currentWidth = Math.min(maxWidth, this.currentWidth + increment);
|
|
152
|
-
break;
|
|
153
|
-
case 'ArrowLeft':
|
|
154
|
-
this.currentWidth = Math.max(this.minBoxSize, this.currentWidth - increment);
|
|
155
|
-
break;
|
|
156
|
-
case 'ArrowDown':
|
|
157
|
-
const maxHeight = rect.height - this.drawStartY;
|
|
158
|
-
this.currentHeight = Math.min(maxHeight, this.currentHeight + increment);
|
|
159
|
-
break;
|
|
160
|
-
case 'ArrowUp':
|
|
161
|
-
this.currentHeight = Math.max(this.minBoxSize, this.currentHeight - increment);
|
|
162
|
-
break;
|
|
163
|
-
}
|
|
164
|
-
this.emitDrawingUpdated();
|
|
165
|
-
}
|
|
166
|
-
confirmDrawing() {
|
|
167
|
-
this.emitDrawingConfirmed();
|
|
168
|
-
this.cleanup();
|
|
169
|
-
}
|
|
170
|
-
cancelDrawing() {
|
|
171
|
-
this.drawingCancelled.emit();
|
|
172
|
-
this.cleanup();
|
|
173
|
-
}
|
|
174
|
-
hideCursor() {
|
|
175
|
-
this.showCursor = false;
|
|
176
|
-
this.emitCursorPosition();
|
|
177
|
-
}
|
|
178
|
-
cleanup() {
|
|
179
|
-
this.isDrawing = false;
|
|
180
|
-
this.showCursor = false;
|
|
181
|
-
this.cursorX = undefined;
|
|
182
|
-
this.cursorY = undefined;
|
|
183
|
-
this.drawStartX = undefined;
|
|
184
|
-
this.drawStartY = undefined;
|
|
185
|
-
this.currentWidth = undefined;
|
|
186
|
-
this.currentHeight = undefined;
|
|
187
|
-
}
|
|
188
|
-
emitCursorPosition() {
|
|
189
|
-
this.cursorPositionChanged.emit({
|
|
190
|
-
x: this.cursorX,
|
|
191
|
-
y: this.cursorY,
|
|
192
|
-
visible: this.showCursor
|
|
193
|
-
});
|
|
194
|
-
}
|
|
195
|
-
emitDrawingStarted() {
|
|
196
|
-
this.drawingStarted.emit({
|
|
197
|
-
startX: this.drawStartX,
|
|
198
|
-
startY: this.drawStartY,
|
|
199
|
-
width: this.currentWidth,
|
|
200
|
-
height: this.currentHeight
|
|
201
|
-
});
|
|
202
|
-
}
|
|
203
|
-
emitDrawingUpdated() {
|
|
204
|
-
this.drawingUpdated.emit({
|
|
205
|
-
startX: this.drawStartX,
|
|
206
|
-
startY: this.drawStartY,
|
|
207
|
-
width: this.currentWidth,
|
|
208
|
-
height: this.currentHeight
|
|
209
|
-
});
|
|
210
|
-
}
|
|
211
|
-
emitDrawingConfirmed() {
|
|
212
|
-
this.drawingConfirmed.emit({
|
|
213
|
-
startX: this.drawStartX,
|
|
214
|
-
startY: this.drawStartY,
|
|
215
|
-
width: this.currentWidth,
|
|
216
|
-
height: this.currentHeight
|
|
217
|
-
});
|
|
218
|
-
}
|
|
219
|
-
reset() {
|
|
220
|
-
this.cleanup();
|
|
221
|
-
this.emitCursorPosition();
|
|
222
|
-
}
|
|
223
|
-
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: KeyboardBoxDrawDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
224
|
-
/** @nocollapse */ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.13", type: KeyboardBoxDrawDirective, selector: "[mvKeyboardBoxDraw]", inputs: { enabled: "enabled", minBoxSize: "minBoxSize", incrementSmall: "incrementSmall", incrementMedium: "incrementMedium", incrementLarge: "incrementLarge" }, outputs: { drawingStarted: "drawingStarted", drawingUpdated: "drawingUpdated", drawingConfirmed: "drawingConfirmed", drawingCancelled: "drawingCancelled", cursorPositionChanged: "cursorPositionChanged" }, host: { listeners: { "keydown": "onKeyDown($event)", "blur": "onBlur()" } }, ngImport: i0 }); }
|
|
225
|
-
}
|
|
226
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: KeyboardBoxDrawDirective, decorators: [{
|
|
227
|
-
type: Directive,
|
|
228
|
-
args: [{
|
|
229
|
-
selector: '[mvKeyboardBoxDraw]'
|
|
230
|
-
}]
|
|
231
|
-
}], ctorParameters: () => [{ type: i0.ElementRef }], propDecorators: { enabled: [{
|
|
232
|
-
type: Input
|
|
233
|
-
}], minBoxSize: [{
|
|
234
|
-
type: Input
|
|
235
|
-
}], incrementSmall: [{
|
|
236
|
-
type: Input
|
|
237
|
-
}], incrementMedium: [{
|
|
238
|
-
type: Input
|
|
239
|
-
}], incrementLarge: [{
|
|
240
|
-
type: Input
|
|
241
|
-
}], drawingStarted: [{
|
|
242
|
-
type: Output
|
|
243
|
-
}], drawingUpdated: [{
|
|
244
|
-
type: Output
|
|
245
|
-
}], drawingConfirmed: [{
|
|
246
|
-
type: Output
|
|
247
|
-
}], drawingCancelled: [{
|
|
248
|
-
type: Output
|
|
249
|
-
}], cursorPositionChanged: [{
|
|
250
|
-
type: Output
|
|
251
|
-
}], onKeyDown: [{
|
|
252
|
-
type: HostListener,
|
|
253
|
-
args: ['keydown', ['$event']]
|
|
254
|
-
}], onBlur: [{
|
|
255
|
-
type: HostListener,
|
|
256
|
-
args: ['blur']
|
|
257
|
-
}] } });
|
|
258
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"keyboard-box-draw.directive.js","sourceRoot":"","sources":["../../../../../../../../projects/media-viewer/src/lib/annotations/annotation-set/annotation-create/box-highlight-create/keyboard-box-draw.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, EventEmitter, HostListener, Input, OnDestroy, Output } from '@angular/core';\n\nexport interface KeyboardBoxDrawEvent {\n  startX: number;\n  startY: number;\n  width: number;\n  height: number;\n}\n\nexport interface CursorPosition {\n  x: number;\n  y: number;\n  visible: boolean;\n}\n\n@Directive({\n  selector: '[mvKeyboardBoxDraw]'\n})\nexport class KeyboardBoxDrawDirective implements OnDestroy {\n\n  @Input() set enabled(value: boolean) {\n    const wasEnabled = this._enabled;\n    this._enabled = value;\n\n    if (value && !wasEnabled && KeyboardBoxDrawDirective.lastInteractionWasKeyboard && !this.showCursor) {\n      this.initializeCursorForKeyboard();\n    }\n  }\n  get enabled(): boolean {\n    return this._enabled;\n  }\n  private _enabled = false;\n\n  @Input() minBoxSize = 10;\n  @Input() incrementSmall = 1;\n  @Input() incrementMedium = 5;\n  @Input() incrementLarge = 10; \n\n  @Output() drawingStarted = new EventEmitter<KeyboardBoxDrawEvent>();\n  @Output() drawingUpdated = new EventEmitter<KeyboardBoxDrawEvent>();\n  @Output() drawingConfirmed = new EventEmitter<KeyboardBoxDrawEvent>();\n  @Output() drawingCancelled = new EventEmitter<void>();\n  @Output() cursorPositionChanged = new EventEmitter<CursorPosition>();\n\n  private isDrawing = false;\n  private cursorX: number;\n  private cursorY: number;\n  private showCursor = false;\n  private drawStartX: number;\n  private drawStartY: number;\n  private currentWidth: number;\n  private currentHeight: number;\n  private static lastInteractionWasKeyboard = false;\n\n  constructor(private elementRef: ElementRef<HTMLElement>) {\n    if (typeof window !== 'undefined') {\n      window.addEventListener('keydown', KeyboardBoxDrawDirective.onGlobalKeyDown, { capture: true });\n      window.addEventListener('mousedown', KeyboardBoxDrawDirective.onGlobalMouseDown, { capture: true });\n    }\n  }\n\n  private static onGlobalKeyDown(): void {\n    KeyboardBoxDrawDirective.lastInteractionWasKeyboard = true;\n  }\n\n  private static onGlobalMouseDown(): void {\n    KeyboardBoxDrawDirective.lastInteractionWasKeyboard = false;\n  }\n\n  ngOnDestroy(): void {\n    this.cleanup();\n  }\n\n  private initializeCursorForKeyboard(): void {\n    if (this.enabled && !this.showCursor && !this.isDrawing) {\n      const rect = this.elementRef.nativeElement.getBoundingClientRect();\n      if (rect.width > 0 && rect.height > 0) {\n        this.cursorX = rect.width / 2;\n        this.cursorY = rect.height / 2;\n        this.showCursor = true;\n        this.emitCursorPosition();\n      }\n    }\n  }\n\n  @HostListener('keydown', ['$event'])\n  onKeyDown(event: KeyboardEvent): void {\n    if (!this.enabled) {\n      return;\n    }\n\n    if (event.key === 'Enter') {\n      event.preventDefault();\n      event.stopPropagation();\n\n      if (!this.isDrawing) {\n        this.startDrawing();\n      } else {\n        this.confirmDrawing();\n      }\n      return;\n    }\n\n    if (event.key === 'Escape') {\n      event.preventDefault();\n      event.stopPropagation();\n\n      if (this.isDrawing) {\n        this.cancelDrawing();\n      } else if (this.showCursor) {\n        this.hideCursor();\n      }\n      return;\n    }\n\n    if (['ArrowUp', 'ArrowDown', 'ArrowLeft', 'ArrowRight'].includes(event.key)) {\n      event.preventDefault();\n      event.stopPropagation();\n\n      if (this.isDrawing) {\n        this.resizeBox(event);\n      } else {\n        this.moveCursor(event);\n      }\n    }\n  }\n\n  @HostListener('blur')\n  onBlur(): void {\n    if (this.showCursor && !this.isDrawing) {\n      this.hideCursor();\n    }\n  }\n\n  private moveCursor(event: KeyboardEvent): void {\n    const increment = event.shiftKey ? this.incrementLarge : this.incrementMedium;\n\n    if (!this.showCursor) {\n      const rect = this.elementRef.nativeElement.getBoundingClientRect();\n      this.cursorX = rect.width / 2;\n      this.cursorY = rect.height / 2;\n      this.showCursor = true;\n\n      this.emitCursorPosition();\n      return;\n    }\n\n    const rect = this.elementRef.nativeElement.getBoundingClientRect();\n\n    switch (event.key) {\n      case 'ArrowUp':\n        this.cursorY = Math.max(0, this.cursorY - increment);\n        break;\n      case 'ArrowDown':\n        this.cursorY = Math.min(rect.height, this.cursorY + increment);\n        break;\n      case 'ArrowLeft':\n        this.cursorX = Math.max(0, this.cursorX - increment);\n        break;\n      case 'ArrowRight':\n        this.cursorX = Math.min(rect.width, this.cursorX + increment);\n        break;\n    }\n\n    this.emitCursorPosition();\n  }\n\n  private startDrawing(): void {\n    let startX: number;\n    let startY: number;\n\n    if (this.showCursor) {\n      startX = this.cursorX;\n      startY = this.cursorY;\n      this.showCursor = false;\n      this.emitCursorPosition();\n    } else {\n      // default to center\n      const rect = this.elementRef.nativeElement.getBoundingClientRect();\n      startX = rect.width / 2;\n      startY = rect.height / 2;\n    }\n\n    this.isDrawing = true;\n    this.drawStartX = startX;\n    this.drawStartY = startY;\n    this.currentWidth = this.minBoxSize;\n    this.currentHeight = this.minBoxSize;\n\n    this.emitDrawingStarted();\n  }\n\n  private resizeBox(event: KeyboardEvent): void {\n    const increment = event.shiftKey ? this.incrementLarge : this.incrementSmall;\n    const rect = this.elementRef.nativeElement.getBoundingClientRect();\n\n    switch (event.key) {\n      case 'ArrowRight':\n        const maxWidth = rect.width - this.drawStartX;\n        this.currentWidth = Math.min(maxWidth, this.currentWidth + increment);\n        break;\n      case 'ArrowLeft':\n        this.currentWidth = Math.max(this.minBoxSize, this.currentWidth - increment);\n        break;\n      case 'ArrowDown':\n        const maxHeight = rect.height - this.drawStartY;\n        this.currentHeight = Math.min(maxHeight, this.currentHeight + increment);\n        break;\n      case 'ArrowUp':\n        this.currentHeight = Math.max(this.minBoxSize, this.currentHeight - increment);\n        break;\n    }\n\n    this.emitDrawingUpdated();\n  }\n\n  private confirmDrawing(): void {\n    this.emitDrawingConfirmed();\n    this.cleanup();\n  }\n\n  private cancelDrawing(): void {\n    this.drawingCancelled.emit();\n    this.cleanup();\n  }\n\n  private hideCursor(): void {\n    this.showCursor = false;\n    this.emitCursorPosition();\n  }\n\n  private cleanup(): void {\n    this.isDrawing = false;\n    this.showCursor = false;\n    this.cursorX = undefined;\n    this.cursorY = undefined;\n    this.drawStartX = undefined;\n    this.drawStartY = undefined;\n    this.currentWidth = undefined;\n    this.currentHeight = undefined;\n  }\n\n  private emitCursorPosition(): void {\n    this.cursorPositionChanged.emit({\n      x: this.cursorX,\n      y: this.cursorY,\n      visible: this.showCursor\n    });\n  }\n\n  private emitDrawingStarted(): void {\n    this.drawingStarted.emit({\n      startX: this.drawStartX,\n      startY: this.drawStartY,\n      width: this.currentWidth,\n      height: this.currentHeight\n    });\n  }\n\n  private emitDrawingUpdated(): void {\n    this.drawingUpdated.emit({\n      startX: this.drawStartX,\n      startY: this.drawStartY,\n      width: this.currentWidth,\n      height: this.currentHeight\n    });\n  }\n\n  private emitDrawingConfirmed(): void {\n    this.drawingConfirmed.emit({\n      startX: this.drawStartX,\n      startY: this.drawStartY,\n      width: this.currentWidth,\n      height: this.currentHeight\n    });\n  }\n\n  public reset(): void {\n    this.cleanup();\n    this.emitCursorPosition();\n  }\n}"]}
|
|
@@ -1,122 +0,0 @@
|
|
|
1
|
-
import { Directive, EventEmitter, HostListener, Input, Output } from '@angular/core';
|
|
2
|
-
import { Subject } from 'rxjs';
|
|
3
|
-
import { debounceTime } from 'rxjs/operators';
|
|
4
|
-
import * as i0 from "@angular/core";
|
|
5
|
-
export class KeyboardBoxMoveDirective {
|
|
6
|
-
constructor(elementRef) {
|
|
7
|
-
this.elementRef = elementRef;
|
|
8
|
-
this.enabled = true;
|
|
9
|
-
this.incrementSmall = 1;
|
|
10
|
-
this.incrementLarge = 10;
|
|
11
|
-
this.keyboardMovingChange = new EventEmitter();
|
|
12
|
-
this.boxDelete = new EventEmitter();
|
|
13
|
-
this.moveSubject = new Subject();
|
|
14
|
-
this.isMoving = false;
|
|
15
|
-
this.moveSubscription = this.moveSubject
|
|
16
|
-
.pipe(debounceTime(500))
|
|
17
|
-
.subscribe(() => {
|
|
18
|
-
this.setMoving(false);
|
|
19
|
-
this.emitStoppedEvent();
|
|
20
|
-
});
|
|
21
|
-
}
|
|
22
|
-
ngOnDestroy() {
|
|
23
|
-
if (this.moveSubscription) {
|
|
24
|
-
this.moveSubscription.unsubscribe();
|
|
25
|
-
}
|
|
26
|
-
this.moveSubject.complete();
|
|
27
|
-
}
|
|
28
|
-
onKeyDown(event) {
|
|
29
|
-
if (event.key === 'Delete' || event.key === 'Backspace') {
|
|
30
|
-
event.preventDefault();
|
|
31
|
-
event.stopPropagation();
|
|
32
|
-
this.boxDelete.emit();
|
|
33
|
-
return;
|
|
34
|
-
}
|
|
35
|
-
if (!this.enabled) {
|
|
36
|
-
return;
|
|
37
|
-
}
|
|
38
|
-
if (['ArrowUp', 'ArrowDown', 'ArrowLeft', 'ArrowRight'].includes(event.key)) {
|
|
39
|
-
event.preventDefault();
|
|
40
|
-
event.stopPropagation();
|
|
41
|
-
this.moveBox(event);
|
|
42
|
-
}
|
|
43
|
-
}
|
|
44
|
-
moveBox(event) {
|
|
45
|
-
const element = this.elementRef.nativeElement;
|
|
46
|
-
const increment = event.shiftKey ? this.incrementLarge : this.incrementSmall;
|
|
47
|
-
if (!this.isMoving) {
|
|
48
|
-
this.setMoving(true);
|
|
49
|
-
}
|
|
50
|
-
const currentTop = parseFloat(element.style.top) || 0;
|
|
51
|
-
const currentLeft = parseFloat(element.style.left) || 0;
|
|
52
|
-
const currentWidth = element.offsetWidth;
|
|
53
|
-
const currentHeight = element.offsetHeight;
|
|
54
|
-
let newTop = currentTop;
|
|
55
|
-
let newLeft = currentLeft;
|
|
56
|
-
switch (event.key) {
|
|
57
|
-
case 'ArrowUp':
|
|
58
|
-
newTop = currentTop - increment;
|
|
59
|
-
break;
|
|
60
|
-
case 'ArrowDown':
|
|
61
|
-
newTop = currentTop + increment;
|
|
62
|
-
break;
|
|
63
|
-
case 'ArrowLeft':
|
|
64
|
-
newLeft = currentLeft - increment;
|
|
65
|
-
break;
|
|
66
|
-
case 'ArrowRight':
|
|
67
|
-
newLeft = currentLeft + increment;
|
|
68
|
-
break;
|
|
69
|
-
}
|
|
70
|
-
if (this.movementBounds) {
|
|
71
|
-
newTop = Math.max(0, Math.min(newTop, this.movementBounds.containerHeight - currentHeight));
|
|
72
|
-
newLeft = Math.max(0, Math.min(newLeft, this.movementBounds.containerWidth - currentWidth));
|
|
73
|
-
}
|
|
74
|
-
element.style.top = `${newTop}px`;
|
|
75
|
-
element.style.left = `${newLeft}px`;
|
|
76
|
-
this.moveSubject.next();
|
|
77
|
-
}
|
|
78
|
-
setMoving(moving) {
|
|
79
|
-
if (this.isMoving !== moving) {
|
|
80
|
-
this.isMoving = moving;
|
|
81
|
-
this.keyboardMovingChange.emit(moving);
|
|
82
|
-
}
|
|
83
|
-
}
|
|
84
|
-
emitStoppedEvent() {
|
|
85
|
-
const element = this.elementRef.nativeElement;
|
|
86
|
-
const wasFocused = document.activeElement === element;
|
|
87
|
-
const stoppedEvent = new CustomEvent('stopped', {
|
|
88
|
-
detail: element,
|
|
89
|
-
bubbles: true
|
|
90
|
-
});
|
|
91
|
-
element.dispatchEvent(stoppedEvent);
|
|
92
|
-
if (wasFocused) {
|
|
93
|
-
setTimeout(() => {
|
|
94
|
-
element.focus();
|
|
95
|
-
}, 50);
|
|
96
|
-
}
|
|
97
|
-
}
|
|
98
|
-
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: KeyboardBoxMoveDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
99
|
-
/** @nocollapse */ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.13", type: KeyboardBoxMoveDirective, selector: "[mvKeyboardBoxMove]", inputs: { enabled: "enabled", incrementSmall: "incrementSmall", incrementLarge: "incrementLarge", movementBounds: "movementBounds" }, outputs: { keyboardMovingChange: "keyboardMovingChange", boxDelete: "boxDelete" }, host: { listeners: { "keydown": "onKeyDown($event)" } }, ngImport: i0 }); }
|
|
100
|
-
}
|
|
101
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: KeyboardBoxMoveDirective, decorators: [{
|
|
102
|
-
type: Directive,
|
|
103
|
-
args: [{
|
|
104
|
-
selector: '[mvKeyboardBoxMove]'
|
|
105
|
-
}]
|
|
106
|
-
}], ctorParameters: () => [{ type: i0.ElementRef }], propDecorators: { enabled: [{
|
|
107
|
-
type: Input
|
|
108
|
-
}], incrementSmall: [{
|
|
109
|
-
type: Input
|
|
110
|
-
}], incrementLarge: [{
|
|
111
|
-
type: Input
|
|
112
|
-
}], movementBounds: [{
|
|
113
|
-
type: Input
|
|
114
|
-
}], keyboardMovingChange: [{
|
|
115
|
-
type: Output
|
|
116
|
-
}], boxDelete: [{
|
|
117
|
-
type: Output
|
|
118
|
-
}], onKeyDown: [{
|
|
119
|
-
type: HostListener,
|
|
120
|
-
args: ['keydown', ['$event']]
|
|
121
|
-
}] } });
|
|
122
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"keyboard-box-move.directive.js","sourceRoot":"","sources":["../../../../../../../../projects/media-viewer/src/lib/annotations/annotation-set/annotation-view/rectangle/keyboard-box-move.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, EventEmitter, HostListener, Input, OnDestroy, Output } from '@angular/core';\nimport { Subject, Subscription } from 'rxjs';\nimport { debounceTime } from 'rxjs/operators';\n\nexport interface BoxMovementBounds {\n  containerWidth: number;\n  containerHeight: number;\n}\n\n@Directive({\n  selector: '[mvKeyboardBoxMove]'\n})\nexport class KeyboardBoxMoveDirective implements OnDestroy {\n\n  @Input() enabled = true;\n  @Input() incrementSmall = 1;\n  @Input() incrementLarge = 10;\n  @Input() movementBounds: BoxMovementBounds;\n\n  @Output() keyboardMovingChange = new EventEmitter<boolean>();\n  @Output() boxDelete = new EventEmitter<void>();\n\n  private moveSubject = new Subject<void>();\n  private moveSubscription: Subscription;\n  private isMoving = false;\n\n  constructor(private elementRef: ElementRef<HTMLElement>) {\n    this.moveSubscription = this.moveSubject\n      .pipe(debounceTime(500))\n      .subscribe(() => {\n        this.setMoving(false);\n        this.emitStoppedEvent();\n      });\n  }\n\n  ngOnDestroy(): void {\n    if (this.moveSubscription) {\n      this.moveSubscription.unsubscribe();\n    }\n    this.moveSubject.complete();\n  }\n\n  @HostListener('keydown', ['$event'])\n  onKeyDown(event: KeyboardEvent): void {\n    if (event.key === 'Delete' || event.key === 'Backspace') {\n      event.preventDefault();\n      event.stopPropagation();\n      this.boxDelete.emit();\n      return;\n    }\n\n    if (!this.enabled) {\n      return;\n    }\n\n    if (['ArrowUp', 'ArrowDown', 'ArrowLeft', 'ArrowRight'].includes(event.key)) {\n      event.preventDefault();\n      event.stopPropagation();\n      this.moveBox(event);\n    }\n  }\n\n  private moveBox(event: KeyboardEvent): void {\n    const element = this.elementRef.nativeElement;\n    const increment = event.shiftKey ? this.incrementLarge : this.incrementSmall;\n\n    if (!this.isMoving) {\n      this.setMoving(true);\n    }\n\n    const currentTop = parseFloat(element.style.top) || 0;\n    const currentLeft = parseFloat(element.style.left) || 0;\n    const currentWidth = element.offsetWidth;\n    const currentHeight = element.offsetHeight;\n\n    let newTop = currentTop;\n    let newLeft = currentLeft;\n\n    switch (event.key) {\n      case 'ArrowUp':\n        newTop = currentTop - increment;\n        break;\n      case 'ArrowDown':\n        newTop = currentTop + increment;\n        break;\n      case 'ArrowLeft':\n        newLeft = currentLeft - increment;\n        break;\n      case 'ArrowRight':\n        newLeft = currentLeft + increment;\n        break;\n    }\n\n    if (this.movementBounds) {\n      newTop = Math.max(0, Math.min(newTop, this.movementBounds.containerHeight - currentHeight));\n      newLeft = Math.max(0, Math.min(newLeft, this.movementBounds.containerWidth - currentWidth));\n    }\n\n    element.style.top = `${newTop}px`;\n    element.style.left = `${newLeft}px`;\n\n    this.moveSubject.next();\n  }\n\n  private setMoving(moving: boolean): void {\n    if (this.isMoving !== moving) {\n      this.isMoving = moving;\n      this.keyboardMovingChange.emit(moving);\n    }\n  }\n\n  private emitStoppedEvent(): void {\n    const element = this.elementRef.nativeElement;\n\n    const wasFocused = document.activeElement === element;\n\n    const stoppedEvent = new CustomEvent('stopped', {\n      detail: element,\n      bubbles: true\n    });\n    element.dispatchEvent(stoppedEvent);\n\n    if (wasFocused) {\n      setTimeout(() => {\n        element.focus();\n      }, 50);\n    }\n  }\n}"]}
|
|
@@ -1,59 +0,0 @@
|
|
|
1
|
-
import { ElementRef, EventEmitter, OnDestroy } from '@angular/core';
|
|
2
|
-
import * as i0 from "@angular/core";
|
|
3
|
-
export interface KeyboardBoxDrawEvent {
|
|
4
|
-
startX: number;
|
|
5
|
-
startY: number;
|
|
6
|
-
width: number;
|
|
7
|
-
height: number;
|
|
8
|
-
}
|
|
9
|
-
export interface CursorPosition {
|
|
10
|
-
x: number;
|
|
11
|
-
y: number;
|
|
12
|
-
visible: boolean;
|
|
13
|
-
}
|
|
14
|
-
export declare class KeyboardBoxDrawDirective implements OnDestroy {
|
|
15
|
-
private elementRef;
|
|
16
|
-
set enabled(value: boolean);
|
|
17
|
-
get enabled(): boolean;
|
|
18
|
-
private _enabled;
|
|
19
|
-
minBoxSize: number;
|
|
20
|
-
incrementSmall: number;
|
|
21
|
-
incrementMedium: number;
|
|
22
|
-
incrementLarge: number;
|
|
23
|
-
drawingStarted: EventEmitter<KeyboardBoxDrawEvent>;
|
|
24
|
-
drawingUpdated: EventEmitter<KeyboardBoxDrawEvent>;
|
|
25
|
-
drawingConfirmed: EventEmitter<KeyboardBoxDrawEvent>;
|
|
26
|
-
drawingCancelled: EventEmitter<void>;
|
|
27
|
-
cursorPositionChanged: EventEmitter<CursorPosition>;
|
|
28
|
-
private isDrawing;
|
|
29
|
-
private cursorX;
|
|
30
|
-
private cursorY;
|
|
31
|
-
private showCursor;
|
|
32
|
-
private drawStartX;
|
|
33
|
-
private drawStartY;
|
|
34
|
-
private currentWidth;
|
|
35
|
-
private currentHeight;
|
|
36
|
-
private static lastInteractionWasKeyboard;
|
|
37
|
-
constructor(elementRef: ElementRef<HTMLElement>);
|
|
38
|
-
private static onGlobalKeyDown;
|
|
39
|
-
private static onGlobalMouseDown;
|
|
40
|
-
ngOnDestroy(): void;
|
|
41
|
-
private initializeCursorForKeyboard;
|
|
42
|
-
onKeyDown(event: KeyboardEvent): void;
|
|
43
|
-
onBlur(): void;
|
|
44
|
-
private moveCursor;
|
|
45
|
-
private startDrawing;
|
|
46
|
-
private resizeBox;
|
|
47
|
-
private confirmDrawing;
|
|
48
|
-
private cancelDrawing;
|
|
49
|
-
private hideCursor;
|
|
50
|
-
private cleanup;
|
|
51
|
-
private emitCursorPosition;
|
|
52
|
-
private emitDrawingStarted;
|
|
53
|
-
private emitDrawingUpdated;
|
|
54
|
-
private emitDrawingConfirmed;
|
|
55
|
-
reset(): void;
|
|
56
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<KeyboardBoxDrawDirective, never>;
|
|
57
|
-
static ɵdir: i0.ɵɵDirectiveDeclaration<KeyboardBoxDrawDirective, "[mvKeyboardBoxDraw]", never, { "enabled": { "alias": "enabled"; "required": false; }; "minBoxSize": { "alias": "minBoxSize"; "required": false; }; "incrementSmall": { "alias": "incrementSmall"; "required": false; }; "incrementMedium": { "alias": "incrementMedium"; "required": false; }; "incrementLarge": { "alias": "incrementLarge"; "required": false; }; }, { "drawingStarted": "drawingStarted"; "drawingUpdated": "drawingUpdated"; "drawingConfirmed": "drawingConfirmed"; "drawingCancelled": "drawingCancelled"; "cursorPositionChanged": "cursorPositionChanged"; }, never, never, false, never>;
|
|
58
|
-
}
|
|
59
|
-
//# sourceMappingURL=keyboard-box-draw.directive.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"keyboard-box-draw.directive.d.ts","sourceRoot":"","sources":["../../../../../../../projects/media-viewer/src/lib/annotations/annotation-set/annotation-create/box-highlight-create/keyboard-box-draw.directive.ts"],"names":[],"mappings":"AAAA,OAAO,EAAa,UAAU,EAAE,YAAY,EAAuB,SAAS,EAAU,MAAM,eAAe,CAAC;;AAE5G,MAAM,WAAW,oBAAoB;IACnC,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,MAAM,CAAC;IACf,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,MAAM,CAAC;CAChB;AAED,MAAM,WAAW,cAAc;IAC7B,CAAC,EAAE,MAAM,CAAC;IACV,CAAC,EAAE,MAAM,CAAC;IACV,OAAO,EAAE,OAAO,CAAC;CAClB;AAED,qBAGa,wBAAyB,YAAW,SAAS;IAoC5C,OAAO,CAAC,UAAU;IAlC9B,IAAa,OAAO,CAAC,KAAK,EAAE,OAAO,EAOlC;IACD,IAAI,OAAO,IAAI,OAAO,CAErB;IACD,OAAO,CAAC,QAAQ,CAAS;IAEhB,UAAU,SAAM;IAChB,cAAc,SAAK;IACnB,eAAe,SAAK;IACpB,cAAc,SAAM;IAEnB,cAAc,qCAA4C;IAC1D,cAAc,qCAA4C;IAC1D,gBAAgB,qCAA4C;IAC5D,gBAAgB,qBAA4B;IAC5C,qBAAqB,+BAAsC;IAErE,OAAO,CAAC,SAAS,CAAS;IAC1B,OAAO,CAAC,OAAO,CAAS;IACxB,OAAO,CAAC,OAAO,CAAS;IACxB,OAAO,CAAC,UAAU,CAAS;IAC3B,OAAO,CAAC,UAAU,CAAS;IAC3B,OAAO,CAAC,UAAU,CAAS;IAC3B,OAAO,CAAC,YAAY,CAAS;IAC7B,OAAO,CAAC,aAAa,CAAS;IAC9B,OAAO,CAAC,MAAM,CAAC,0BAA0B,CAAS;gBAE9B,UAAU,EAAE,UAAU,CAAC,WAAW,CAAC;IAOvD,OAAO,CAAC,MAAM,CAAC,eAAe;IAI9B,OAAO,CAAC,MAAM,CAAC,iBAAiB;IAIhC,WAAW,IAAI,IAAI;IAInB,OAAO,CAAC,2BAA2B;IAanC,SAAS,CAAC,KAAK,EAAE,aAAa,GAAG,IAAI;IA0CrC,MAAM,IAAI,IAAI;IAMd,OAAO,CAAC,UAAU;IAiClB,OAAO,CAAC,YAAY;IAyBpB,OAAO,CAAC,SAAS;IAwBjB,OAAO,CAAC,cAAc;IAKtB,OAAO,CAAC,aAAa;IAKrB,OAAO,CAAC,UAAU;IAKlB,OAAO,CAAC,OAAO;IAWf,OAAO,CAAC,kBAAkB;IAQ1B,OAAO,CAAC,kBAAkB;IAS1B,OAAO,CAAC,kBAAkB;IAS1B,OAAO,CAAC,oBAAoB;IASrB,KAAK,IAAI,IAAI;yCAnQT,wBAAwB;2CAAxB,wBAAwB;CAuQpC"}
|
package/lib/annotations/annotation-set/annotation-view/rectangle/keyboard-box-move.directive.d.ts
DELETED
|
@@ -1,27 +0,0 @@
|
|
|
1
|
-
import { ElementRef, EventEmitter, OnDestroy } from '@angular/core';
|
|
2
|
-
import * as i0 from "@angular/core";
|
|
3
|
-
export interface BoxMovementBounds {
|
|
4
|
-
containerWidth: number;
|
|
5
|
-
containerHeight: number;
|
|
6
|
-
}
|
|
7
|
-
export declare class KeyboardBoxMoveDirective implements OnDestroy {
|
|
8
|
-
private elementRef;
|
|
9
|
-
enabled: boolean;
|
|
10
|
-
incrementSmall: number;
|
|
11
|
-
incrementLarge: number;
|
|
12
|
-
movementBounds: BoxMovementBounds;
|
|
13
|
-
keyboardMovingChange: EventEmitter<boolean>;
|
|
14
|
-
boxDelete: EventEmitter<void>;
|
|
15
|
-
private moveSubject;
|
|
16
|
-
private moveSubscription;
|
|
17
|
-
private isMoving;
|
|
18
|
-
constructor(elementRef: ElementRef<HTMLElement>);
|
|
19
|
-
ngOnDestroy(): void;
|
|
20
|
-
onKeyDown(event: KeyboardEvent): void;
|
|
21
|
-
private moveBox;
|
|
22
|
-
private setMoving;
|
|
23
|
-
private emitStoppedEvent;
|
|
24
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<KeyboardBoxMoveDirective, never>;
|
|
25
|
-
static ɵdir: i0.ɵɵDirectiveDeclaration<KeyboardBoxMoveDirective, "[mvKeyboardBoxMove]", never, { "enabled": { "alias": "enabled"; "required": false; }; "incrementSmall": { "alias": "incrementSmall"; "required": false; }; "incrementLarge": { "alias": "incrementLarge"; "required": false; }; "movementBounds": { "alias": "movementBounds"; "required": false; }; }, { "keyboardMovingChange": "keyboardMovingChange"; "boxDelete": "boxDelete"; }, never, never, false, never>;
|
|
26
|
-
}
|
|
27
|
-
//# sourceMappingURL=keyboard-box-move.directive.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"keyboard-box-move.directive.d.ts","sourceRoot":"","sources":["../../../../../../../projects/media-viewer/src/lib/annotations/annotation-set/annotation-view/rectangle/keyboard-box-move.directive.ts"],"names":[],"mappings":"AAAA,OAAO,EAAa,UAAU,EAAE,YAAY,EAAuB,SAAS,EAAU,MAAM,eAAe,CAAC;;AAI5G,MAAM,WAAW,iBAAiB;IAChC,cAAc,EAAE,MAAM,CAAC;IACvB,eAAe,EAAE,MAAM,CAAC;CACzB;AAED,qBAGa,wBAAyB,YAAW,SAAS;IAc5C,OAAO,CAAC,UAAU;IAZrB,OAAO,UAAQ;IACf,cAAc,SAAK;IACnB,cAAc,SAAM;IACpB,cAAc,EAAE,iBAAiB,CAAC;IAEjC,oBAAoB,wBAA+B;IACnD,SAAS,qBAA4B;IAE/C,OAAO,CAAC,WAAW,CAAuB;IAC1C,OAAO,CAAC,gBAAgB,CAAe;IACvC,OAAO,CAAC,QAAQ,CAAS;gBAEL,UAAU,EAAE,UAAU,CAAC,WAAW,CAAC;IASvD,WAAW,IAAI,IAAI;IAQnB,SAAS,CAAC,KAAK,EAAE,aAAa,GAAG,IAAI;IAmBrC,OAAO,CAAC,OAAO;IA0Cf,OAAO,CAAC,SAAS;IAOjB,OAAO,CAAC,gBAAgB;yCAnGb,wBAAwB;2CAAxB,wBAAwB;CAoHpC"}
|