@hmcts/media-viewer 2.7.21 → 2.7.23
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/bundles/hmcts-media-viewer.umd.js +4890 -4755
- package/bundles/hmcts-media-viewer.umd.js.map +1 -1
- package/bundles/hmcts-media-viewer.umd.min.js +1 -1
- package/bundles/hmcts-media-viewer.umd.min.js.map +1 -1
- package/esm2015/hmcts-media-viewer.js +20 -20
- package/esm2015/lib/annotations/annotation-set/annotation-create/box-highlight-create/box-highlight-create.component.js +8 -2
- package/esm2015/lib/icp/icp-update.service.js +22 -40
- package/esm2015/lib/icp/icp.events.js +20 -0
- package/esm2015/lib/icp/icp.interfaces.js +3 -1
- package/esm2015/lib/icp/socket.service.js +133 -43
- package/esm2015/lib/media-viewer.component.js +2 -2
- package/esm2015/lib/viewers/image-viewer/image-viewer.component.js +33 -6
- package/esm2015/lib/viewers/pdf-viewer/pdf-viewer.component.js +11 -2
- package/esm5/hmcts-media-viewer.js +20 -20
- package/esm5/lib/annotations/annotation-set/annotation-create/box-highlight-create/box-highlight-create.component.js +8 -2
- package/esm5/lib/icp/icp-update.service.js +23 -40
- package/esm5/lib/icp/icp.events.js +20 -0
- package/esm5/lib/icp/icp.interfaces.js +3 -1
- package/esm5/lib/icp/socket.service.js +143 -45
- package/esm5/lib/media-viewer.component.js +2 -2
- package/esm5/lib/viewers/image-viewer/image-viewer.component.js +36 -6
- package/esm5/lib/viewers/pdf-viewer/pdf-viewer.component.js +10 -2
- package/fesm2015/hmcts-media-viewer.js +4198 -4074
- package/fesm2015/hmcts-media-viewer.js.map +1 -1
- package/fesm5/hmcts-media-viewer.js +4873 -4738
- package/fesm5/hmcts-media-viewer.js.map +1 -1
- package/hmcts-media-viewer-v2.7.23.tgz +0 -0
- package/hmcts-media-viewer.d.ts +19 -19
- package/hmcts-media-viewer.metadata.json +1 -1
- package/lib/annotations/annotation-set/annotation-create/box-highlight-create/box-highlight-create.component.d.ts +4 -3
- package/lib/icp/icp-update.service.d.ts +0 -9
- package/lib/icp/icp.events.d.ts +13 -0
- package/lib/icp/icp.interfaces.d.ts +1 -0
- package/lib/icp/socket.service.d.ts +13 -4
- package/lib/viewers/image-viewer/image-viewer.component.d.ts +4 -1
- package/lib/viewers/pdf-viewer/pdf-viewer.component.d.ts +3 -1
- package/package.json +1 -1
- package/hmcts-media-viewer-v2.7.21.tgz +0 -0
|
@@ -3,11 +3,17 @@
|
|
|
3
3
|
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
|
|
4
4
|
*/
|
|
5
5
|
import { Injectable } from '@angular/core';
|
|
6
|
-
import { BehaviorSubject,
|
|
7
|
-
import
|
|
6
|
+
import { BehaviorSubject, of, Subject } from 'rxjs';
|
|
7
|
+
import { IcpEvents } from './icp.events';
|
|
8
8
|
export class SocketService {
|
|
9
9
|
constructor() {
|
|
10
10
|
this.connected$ = new BehaviorSubject(false);
|
|
11
|
+
this.sessionJoined$ = new Subject();
|
|
12
|
+
this.presenterUpdated$ = new Subject();
|
|
13
|
+
this.clientDisconnected$ = new Subject();
|
|
14
|
+
this.participantUpdated$ = new Subject();
|
|
15
|
+
this.newParticipantJoined$ = new Subject();
|
|
16
|
+
this.screenUpdated$ = new Subject();
|
|
11
17
|
}
|
|
12
18
|
/**
|
|
13
19
|
* @return {?}
|
|
@@ -16,40 +22,69 @@ export class SocketService {
|
|
|
16
22
|
this.subscription.unsubscribe();
|
|
17
23
|
}
|
|
18
24
|
/**
|
|
25
|
+
* @param {?} url
|
|
19
26
|
* @return {?}
|
|
20
27
|
*/
|
|
21
|
-
connect() {
|
|
22
|
-
|
|
23
|
-
|
|
28
|
+
connect(url) {
|
|
29
|
+
return this.getSocketClient(url).subscribe((/**
|
|
30
|
+
* @param {?} socket
|
|
24
31
|
* @return {?}
|
|
25
32
|
*/
|
|
26
|
-
() =>
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
33
|
+
(socket) => {
|
|
34
|
+
socket.onopen = (/**
|
|
35
|
+
* @param {?} event
|
|
36
|
+
* @return {?}
|
|
37
|
+
*/
|
|
38
|
+
(event) => {
|
|
39
|
+
this.connected$.next(true);
|
|
40
|
+
});
|
|
41
|
+
socket.onmessage = (/**
|
|
42
|
+
* @param {?} event
|
|
43
|
+
* @return {?}
|
|
44
|
+
*/
|
|
45
|
+
(event) => {
|
|
46
|
+
console.log('onmessage');
|
|
47
|
+
/** @type {?} */
|
|
48
|
+
const eventData = JSON.parse(event.data);
|
|
49
|
+
if (eventData.data && eventData.data.eventName) {
|
|
50
|
+
this.messageEventHandller(eventData.data.eventName, eventData.data.data);
|
|
51
|
+
}
|
|
52
|
+
});
|
|
53
|
+
socket.onerror = (/**
|
|
54
|
+
* @param {?} event
|
|
55
|
+
* @return {?}
|
|
56
|
+
*/
|
|
57
|
+
(event) => {
|
|
58
|
+
console.log('onerror');
|
|
59
|
+
});
|
|
60
|
+
socket.onclose = (/**
|
|
61
|
+
* @param {?} event
|
|
62
|
+
* @return {?}
|
|
63
|
+
*/
|
|
64
|
+
(event) => {
|
|
65
|
+
console.log('onclose');
|
|
66
|
+
});
|
|
67
|
+
}));
|
|
68
|
+
}
|
|
69
|
+
/**
|
|
70
|
+
* @return {?}
|
|
71
|
+
*/
|
|
72
|
+
connected() {
|
|
73
|
+
return this.connected$.asObservable();
|
|
31
74
|
}
|
|
32
75
|
/**
|
|
33
76
|
* @param {?} session
|
|
34
77
|
* @return {?}
|
|
35
78
|
*/
|
|
36
79
|
join(session) {
|
|
37
|
-
this.
|
|
38
|
-
* @param {?} connected
|
|
39
|
-
* @return {?}
|
|
40
|
-
*/
|
|
41
|
-
connected => {
|
|
42
|
-
if (connected) {
|
|
43
|
-
this.socket.emit('join', session);
|
|
44
|
-
}
|
|
45
|
-
}));
|
|
80
|
+
this.emit(IcpEvents.SESSION_JOIN, session);
|
|
46
81
|
}
|
|
47
82
|
/**
|
|
48
83
|
* @param {?} session
|
|
49
84
|
* @return {?}
|
|
50
85
|
*/
|
|
51
86
|
leave(session) {
|
|
52
|
-
this.
|
|
87
|
+
this.emit(IcpEvents.SESSION_LEAVE, session);
|
|
53
88
|
this.subscription.unsubscribe();
|
|
54
89
|
}
|
|
55
90
|
/**
|
|
@@ -58,38 +93,81 @@ export class SocketService {
|
|
|
58
93
|
* @return {?}
|
|
59
94
|
*/
|
|
60
95
|
emit(event, data) {
|
|
61
|
-
this.socket.
|
|
96
|
+
this.socket.send(JSON.stringify({
|
|
97
|
+
type: 'event',
|
|
98
|
+
event,
|
|
99
|
+
data
|
|
100
|
+
}));
|
|
62
101
|
}
|
|
63
102
|
/**
|
|
64
103
|
* @param {?} event
|
|
65
104
|
* @return {?}
|
|
66
105
|
*/
|
|
67
106
|
listen(event) {
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
107
|
+
switch (event) {
|
|
108
|
+
case IcpEvents.SESSION_JOINED: {
|
|
109
|
+
return this.sessionJoined$.asObservable();
|
|
110
|
+
}
|
|
111
|
+
case IcpEvents.PRESENTER_UPDATED: {
|
|
112
|
+
return this.presenterUpdated$.asObservable();
|
|
113
|
+
}
|
|
114
|
+
case IcpEvents.CLIENT_DISCONNECTED: {
|
|
115
|
+
return this.clientDisconnected$.asObservable();
|
|
116
|
+
}
|
|
117
|
+
case IcpEvents.PARTICIPANTS_UPDATED: {
|
|
118
|
+
return this.participantUpdated$.asObservable();
|
|
119
|
+
}
|
|
120
|
+
case IcpEvents.NEW_PARTICIPANT_JOINED: {
|
|
121
|
+
return this.newParticipantJoined$.asObservable();
|
|
122
|
+
}
|
|
123
|
+
case IcpEvents.SCREEN_UPDATED: {
|
|
124
|
+
return this.screenUpdated$.asObservable();
|
|
125
|
+
}
|
|
126
|
+
default: {
|
|
127
|
+
break;
|
|
128
|
+
}
|
|
129
|
+
}
|
|
85
130
|
}
|
|
86
131
|
/**
|
|
132
|
+
* @param {?} eventName
|
|
133
|
+
* @param {?} data
|
|
87
134
|
* @return {?}
|
|
88
135
|
*/
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
136
|
+
messageEventHandller(eventName, data) {
|
|
137
|
+
switch (eventName) {
|
|
138
|
+
case IcpEvents.SESSION_JOINED: {
|
|
139
|
+
this.sessionJoined$.next(data);
|
|
140
|
+
break;
|
|
141
|
+
}
|
|
142
|
+
case IcpEvents.PRESENTER_UPDATED: {
|
|
143
|
+
this.presenterUpdated$.next(data);
|
|
144
|
+
break;
|
|
145
|
+
}
|
|
146
|
+
case IcpEvents.CLIENT_DISCONNECTED: {
|
|
147
|
+
this.clientDisconnected$.next();
|
|
148
|
+
break;
|
|
149
|
+
}
|
|
150
|
+
case IcpEvents.PARTICIPANTS_UPDATED: {
|
|
151
|
+
this.participantUpdated$.next(data);
|
|
152
|
+
break;
|
|
153
|
+
}
|
|
154
|
+
case IcpEvents.NEW_PARTICIPANT_JOINED: {
|
|
155
|
+
this.newParticipantJoined$.next();
|
|
156
|
+
break;
|
|
157
|
+
}
|
|
158
|
+
case IcpEvents.SCREEN_UPDATED: {
|
|
159
|
+
this.screenUpdated$.next(data);
|
|
160
|
+
break;
|
|
161
|
+
}
|
|
162
|
+
}
|
|
163
|
+
}
|
|
164
|
+
/**
|
|
165
|
+
* @param {?} url
|
|
166
|
+
* @return {?}
|
|
167
|
+
*/
|
|
168
|
+
getSocketClient(url) {
|
|
169
|
+
this.socket = new WebSocket(url, 'json.webpubsub.azure.v1');
|
|
170
|
+
return of(this.socket);
|
|
93
171
|
}
|
|
94
172
|
}
|
|
95
173
|
SocketService.decorators = [
|
|
@@ -107,5 +185,17 @@ if (false) {
|
|
|
107
185
|
SocketService.prototype.subscription;
|
|
108
186
|
/** @type {?} */
|
|
109
187
|
SocketService.prototype.connected$;
|
|
188
|
+
/** @type {?} */
|
|
189
|
+
SocketService.prototype.sessionJoined$;
|
|
190
|
+
/** @type {?} */
|
|
191
|
+
SocketService.prototype.presenterUpdated$;
|
|
192
|
+
/** @type {?} */
|
|
193
|
+
SocketService.prototype.clientDisconnected$;
|
|
194
|
+
/** @type {?} */
|
|
195
|
+
SocketService.prototype.participantUpdated$;
|
|
196
|
+
/** @type {?} */
|
|
197
|
+
SocketService.prototype.newParticipantJoined$;
|
|
198
|
+
/** @type {?} */
|
|
199
|
+
SocketService.prototype.screenUpdated$;
|
|
110
200
|
}
|
|
111
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
201
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"socket.service.js","sourceRoot":"ng://@hmcts/media-viewer/","sources":["lib/icp/socket.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, OnDestroy } from '@angular/core';\nimport { BehaviorSubject, from, Observable, of, Subject, Subscription } from 'rxjs';\nimport { IcpEvents } from './icp.events';\nimport { IcpParticipant } from './icp.interfaces';\n\n@Injectable()\nexport class SocketService implements OnDestroy {\n\n  private socket: WebSocket;\n  subscription: Subscription;\n  connected$ = new BehaviorSubject<boolean>(false);\n  sessionJoined$ = new Subject();\n  presenterUpdated$ = new Subject();\n  clientDisconnected$ = new Subject();\n  participantUpdated$ = new Subject();\n  newParticipantJoined$ = new Subject();\n  screenUpdated$ = new Subject();\n\n  constructor() { }\n\n  ngOnDestroy() {\n    this.subscription.unsubscribe();\n  }\n\n  connect(url: string) {\n    return this.getSocketClient(url).subscribe((socket: WebSocket) => {\n\n      socket.onopen = (event: Event) => {\n        this.connected$.next(true);\n      };\n\n      socket.onmessage = (event: MessageEvent) => {\n        console.log('onmessage');\n        const eventData = JSON.parse(event.data);\n        if (eventData.data && eventData.data.eventName) {\n          this.messageEventHandller(eventData.data.eventName, eventData.data.data);\n        }\n      };\n\n      socket.onerror = (event: Event) => {\n        console.log('onerror');\n      };\n\n      socket.onclose = (event: CloseEvent) => {\n        console.log('onclose');\n      };\n    });\n  }\n\n  connected(): Observable<boolean> {\n    return this.connected$.asObservable();\n  }\n\n  join(session) {\n    this.emit(IcpEvents.SESSION_JOIN, session);\n  }\n\n  leave(session) {\n    this.emit(IcpEvents.SESSION_LEAVE, session);\n    this.subscription.unsubscribe();\n  }\n\n  emit(event: string, data: any) {\n    this.socket.send(JSON.stringify({\n      type: 'event',\n      event,\n      data\n    }));\n  }\n\n  listen(event: IcpEvents): Observable<any> {\n    switch (event) {\n      case IcpEvents.SESSION_JOINED: {\n        return this.sessionJoined$.asObservable();\n      }\n      case IcpEvents.PRESENTER_UPDATED: {\n        return this.presenterUpdated$.asObservable();\n      }\n      case IcpEvents.CLIENT_DISCONNECTED: {\n        return this.clientDisconnected$.asObservable();\n      }\n      case IcpEvents.PARTICIPANTS_UPDATED: {\n        return this.participantUpdated$.asObservable();\n      }\n      case IcpEvents.NEW_PARTICIPANT_JOINED: {\n        return this.newParticipantJoined$.asObservable();\n      }\n      case IcpEvents.SCREEN_UPDATED: {\n        return this.screenUpdated$.asObservable();\n      }\n      default: {\n        break;\n      }\n    }\n  }\n\n  messageEventHandller(eventName: string, data: any) {\n    switch (eventName) {\n      case IcpEvents.SESSION_JOINED: {\n        this.sessionJoined$.next(data);\n        break;\n      }\n      case IcpEvents.PRESENTER_UPDATED: {\n        this.presenterUpdated$.next(data);\n        break;\n      }\n      case IcpEvents.CLIENT_DISCONNECTED: {\n        this.clientDisconnected$.next();\n        break;\n      }\n      case IcpEvents.PARTICIPANTS_UPDATED: {\n        this.participantUpdated$.next(data);\n        break;\n      }\n      case IcpEvents.NEW_PARTICIPANT_JOINED: {\n        this.newParticipantJoined$.next();\n        break;\n      }\n      case IcpEvents.SCREEN_UPDATED: {\n        this.screenUpdated$.next(data);\n        break;\n      }\n    }\n  }\n\n  getSocketClient(url: string): Observable<WebSocket> {\n    this.socket = new WebSocket(url, 'json.webpubsub.azure.v1');\n    return of(this.socket);\n  }\n}\n"]}
|
|
@@ -129,7 +129,7 @@ export class MediaViewerComponent {
|
|
|
129
129
|
if (this.enableAnnotations && !(this.multimediaContent || this.unsupportedContent)) {
|
|
130
130
|
this.store.dispatch(new fromAnnoActions.LoadAnnotationSet(this.documentId));
|
|
131
131
|
}
|
|
132
|
-
if (this.enableRedactions && !(this.multimediaContent || this.unsupportedContent)) {
|
|
132
|
+
if (this.enableRedactions && !(this.multimediaContent || this.unsupportedContent) && this.documentId) {
|
|
133
133
|
this.store.dispatch(new fromRedactActions.LoadRedactions(this.documentId));
|
|
134
134
|
}
|
|
135
135
|
if (this.contentType === 'image') {
|
|
@@ -378,4 +378,4 @@ if (false) {
|
|
|
378
378
|
*/
|
|
379
379
|
MediaViewerComponent.prototype.cdr;
|
|
380
380
|
}
|
|
381
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"media-viewer.component.js","sourceRoot":"ng://@hmcts/media-viewer/","sources":["lib/media-viewer.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit, AfterViewChecked,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Output,\n  SimpleChanges,\n  ViewChild,\n  ViewEncapsulation\n} from '@angular/core';\nimport { Observable, Subscription } from 'rxjs';\nimport {\n  defaultImageOptions, defaultMultimediaOptions,\n  defaultPdfOptions,\n  defaultUnsupportedOptions,\n  ToolbarButtonVisibilityService\n} from './toolbar/toolbar-button-visibility.service';\nimport { AnnotationSet } from './annotations/annotation-set/annotation-set.model';\nimport { ToolbarEventService } from './toolbar/toolbar-event.service';\nimport { AnnotationApiService } from './annotations/services/annotation-api/annotation-api.service';\nimport { ResponseType, ViewerException } from './viewers/viewer-exception.model';\nimport { CommentService } from './annotations/comment-set/comment/comment.service';\nimport 'hammerjs';\nimport { select, Store } from '@ngrx/store';\nimport * as fromStore from './store/reducers/reducers';\nimport * as fromAnnoSelectors from './store/selectors/annotation.selectors';\nimport * as fromDocumentsSelector from './store/selectors/document.selectors';\nimport * as fromAnnoActions from './store/actions/annotation.actions';\nimport * as fromRedactActions from './store/actions/redaction.actions';\nimport * as fromDocumentActions from './store/actions/document.actions';\n\nenum CoreContentTypes {\n  PDF = 'pdf',\n  IMAGE = 'image'\n}\n\nenum MultimediaContentTypes {\n  MP4 = 'mp4',\n  MP3 = 'mp3',\n}\n\nenum ConvertibleContentTypes {\n  EXCEL = 'excel',\n  WORD = 'word',\n  POWERPOINT = 'powerpoint',\n  TXT = 'txt',\n  RTF = 'rtf'\n}\n\n@Component({\n  selector: 'mv-media-viewer',\n  templateUrl: './media-viewer.component.html',\n  encapsulation: ViewEncapsulation.None\n})\nexport class MediaViewerComponent implements OnChanges, OnDestroy, AfterContentInit, AfterViewChecked {\n\n  @ViewChild('viewerRef') viewerRef: ElementRef;\n\n  @Input() url;\n  @Input() downloadFileName: string;\n  @Input() contentType: string;\n\n  @Input() showToolbar = true;\n  @Input() toolbarButtonOverrides: any = {};\n\n  @Input()\n  public height: string;\n  public viewerHeight: string;\n\n  @Input() width = '100%';\n\n  @Output() mediaLoadStatus = new EventEmitter<ResponseType>();\n  @Output() viewerException = new EventEmitter<ViewerException>();\n  @Output() toolbarEventsOutput = new EventEmitter<ToolbarEventService>();\n  @Output() unsavedChanges = new EventEmitter<boolean>();\n\n  @Input() enableAnnotations = false;\n  @Input() annotationApiUrl;\n\n  @Input() enableRedactions = false;\n  @Input() enableICP = false;\n  @Input() multimediaPlayerEnabled = false;\n\n\n  @Input() caseId: string;\n\n  multimediaContent = false;\n  convertibleContent = false;\n  unsupportedContent = false;\n\n  documentTitle: string;\n  showCommentSummary: boolean;\n  annotationSet$: Observable<AnnotationSet | {}>;\n  hasScrollBar: boolean;\n  typeException = false;\n  hasDifferentPageSize$: Observable<boolean>;\n  documentId: string;\n\n  private $subscriptions: Subscription;\n  private prevOffset: number;\n\n  constructor(\n    private store: Store<fromStore.AnnotationSetState>,\n    public readonly toolbarButtons: ToolbarButtonVisibilityService,\n    public readonly toolbarEvents: ToolbarEventService,\n    private readonly api: AnnotationApiService,\n    private readonly commentService: CommentService,\n    private elRef: ElementRef,\n    private cdr: ChangeDetectorRef\n  ) {\n    if (this.annotationApiUrl) {\n      api.annotationApiUrl = this.annotationApiUrl;\n    }\n  }\n\n  ngAfterContentInit() {\n    this.annotationSet$ = this.store.pipe(select(fromAnnoSelectors.getAnnotationSet));\n    this.hasDifferentPageSize$ = this.store.pipe(select(fromDocumentsSelector.getPageDifference));\n    this.setToolbarButtons();\n    this.toolbarEventsOutput.emit(this.toolbarEvents);\n    this.$subscriptions = this.commentService.getUnsavedChanges()\n      .subscribe(changes => this.onCommentChange(changes));\n    this.$subscriptions.add(this.toolbarEvents.getShowCommentSummary()\n      .subscribe(changes => this.showCommentSummary = changes));\n  }\n\n  ngAfterViewChecked(): void {\n    if (this.height && this.viewerHeight !== this.height) {\n      this.viewerHeight = this.height;\n      this.cdr.detectChanges();\n      return;\n    }\n\n    if (!this.height) {\n      const compOffsetTop = this.elRef.nativeElement.getBoundingClientRect().top;\n      const viewerOffsetTop = this.viewerRef.nativeElement.offsetTop;\n      const offset = compOffsetTop + viewerOffsetTop;\n\n      if (this.prevOffset !== offset) {\n        this.viewerHeight = `calc(100vh - ${offset}px)`;\n        this.prevOffset = offset;\n        this.cdr.detectChanges();\n      }\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes.annotationApiUrl) {\n      this.api.annotationApiUrl = this.annotationApiUrl;\n    }\n\n    if (changes.url) {\n      this.toolbarEvents.reset();\n      this.commentService.resetCommentSet();\n      this.documentId = this.extractDMStoreDocId(this.url);\n      this.store.dispatch(new fromDocumentActions.SetDocumentId(this.documentId));\n      if (this.enableAnnotations && !(this.multimediaContent || this.unsupportedContent)) {\n        this.store.dispatch(new fromAnnoActions.LoadAnnotationSet(this.documentId));\n      }\n      if (this.enableRedactions && !(this.multimediaContent || this.unsupportedContent)) {\n        this.store.dispatch(new fromRedactActions.LoadRedactions(this.documentId));\n      }\n      if (this.contentType === 'image') {\n        this.documentTitle = null;\n      }\n    }\n\n    if (changes.contentType) {\n      this.convertibleContent = this.needsConverting();\n      this.multimediaContent = this.isMultimedia();\n      this.unsupportedContent = !this.isSupported();\n    }\n\n    this.setToolbarButtons();\n    this.detectOs();\n    this.typeException = false;\n  }\n\n  ngOnDestroy() {\n    this.$subscriptions.unsubscribe();\n  }\n\n  needsConverting(): boolean {\n    return this.contentType !== null && Object.keys(ConvertibleContentTypes).includes(this.contentType.toUpperCase());\n  }\n\n  isMultimedia(): boolean {\n    return this.contentType !== null && Object.keys(MultimediaContentTypes).includes(this.contentType.toUpperCase());\n  }\n\n  isSupported(): boolean {\n    const supportedTypes = Object.assign({}, MultimediaContentTypes, ConvertibleContentTypes, CoreContentTypes);\n    return this.contentType !== null && Object.keys(supportedTypes).includes(this.contentType.toUpperCase());\n  }\n\n  onMediaLoad(status: ResponseType) {\n    this.mediaLoadStatus.emit(status);\n  }\n\n  setToolbarButtons() {\n    if (this.contentType === CoreContentTypes.PDF || this.needsConverting()) {\n      this.toolbarButtons.setup({\n        ...defaultPdfOptions, showHighlightButton: this.enableAnnotations, showDrawButton: this.enableAnnotations,\n        ...this.toolbarButtonOverrides\n      });\n    } else if (this.contentType === CoreContentTypes.IMAGE) {\n      this.toolbarButtons.setup({\n        ...defaultImageOptions, showDrawButton: this.enableAnnotations,\n        ...this.toolbarButtonOverrides\n      });\n    } else if (this.isMultimedia()) {\n      this.toolbarButtons.setup({\n        ...defaultMultimediaOptions,\n        ...this.toolbarButtonOverrides\n      });\n    } else {\n      this.toolbarButtons.setup({\n        ...defaultUnsupportedOptions,\n        ...this.toolbarButtonOverrides\n      });\n    }\n  }\n\n  onLoadException(exception: ViewerException) {\n    this.viewerException.emit(exception);\n    if (!this.isSupported()) {\n      this.typeException = false;\n    } else {\n      this.typeException = true;\n      this.contentType = null;\n      this.setToolbarButtons();\n    }\n  }\n\n  onCommentChange(changes: boolean) {\n    this.unsavedChanges.emit(changes);\n  }\n\n  onDocumentTitleChange(title: string) {\n    this.documentTitle = title;\n  }\n\n  // If secure mode is enabled (which adds \"documentsv2\" to the documentId), get rid of it\n  private extractDMStoreDocId(url: string): string {\n    url = url.includes('/documents/') ? url.split('/documents/')[1] : url;\n    url = url.includes('/documentsv2/') ? url.split('/documentsv2/')[1] : url;\n    return url.replace('/binary', '');\n  }\n\n  detectOs() {\n    this.hasScrollBar = window.navigator.userAgent.indexOf('Win') !== -1;\n  }\n}\n"]}
|
|
381
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"media-viewer.component.js","sourceRoot":"ng://@hmcts/media-viewer/","sources":["lib/media-viewer.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit, AfterViewChecked,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Output,\n  SimpleChanges,\n  ViewChild,\n  ViewEncapsulation\n} from '@angular/core';\nimport { Observable, Subscription } from 'rxjs';\nimport {\n  defaultImageOptions, defaultMultimediaOptions,\n  defaultPdfOptions,\n  defaultUnsupportedOptions,\n  ToolbarButtonVisibilityService\n} from './toolbar/toolbar-button-visibility.service';\nimport { AnnotationSet } from './annotations/annotation-set/annotation-set.model';\nimport { ToolbarEventService } from './toolbar/toolbar-event.service';\nimport { AnnotationApiService } from './annotations/services/annotation-api/annotation-api.service';\nimport { ResponseType, ViewerException } from './viewers/viewer-exception.model';\nimport { CommentService } from './annotations/comment-set/comment/comment.service';\nimport 'hammerjs';\nimport { select, Store } from '@ngrx/store';\nimport * as fromStore from './store/reducers/reducers';\nimport * as fromAnnoSelectors from './store/selectors/annotation.selectors';\nimport * as fromDocumentsSelector from './store/selectors/document.selectors';\nimport * as fromAnnoActions from './store/actions/annotation.actions';\nimport * as fromRedactActions from './store/actions/redaction.actions';\nimport * as fromDocumentActions from './store/actions/document.actions';\n\nenum CoreContentTypes {\n  PDF = 'pdf',\n  IMAGE = 'image'\n}\n\nenum MultimediaContentTypes {\n  MP4 = 'mp4',\n  MP3 = 'mp3',\n}\n\nenum ConvertibleContentTypes {\n  EXCEL = 'excel',\n  WORD = 'word',\n  POWERPOINT = 'powerpoint',\n  TXT = 'txt',\n  RTF = 'rtf'\n}\n\n@Component({\n  selector: 'mv-media-viewer',\n  templateUrl: './media-viewer.component.html',\n  encapsulation: ViewEncapsulation.None\n})\nexport class MediaViewerComponent implements OnChanges, OnDestroy, AfterContentInit, AfterViewChecked {\n\n  @ViewChild('viewerRef') viewerRef: ElementRef;\n\n  @Input() url;\n  @Input() downloadFileName: string;\n  @Input() contentType: string;\n\n  @Input() showToolbar = true;\n  @Input() toolbarButtonOverrides: any = {};\n\n  @Input()\n  public height: string;\n  public viewerHeight: string;\n\n  @Input() width = '100%';\n\n  @Output() mediaLoadStatus = new EventEmitter<ResponseType>();\n  @Output() viewerException = new EventEmitter<ViewerException>();\n  @Output() toolbarEventsOutput = new EventEmitter<ToolbarEventService>();\n  @Output() unsavedChanges = new EventEmitter<boolean>();\n\n  @Input() enableAnnotations = false;\n  @Input() annotationApiUrl;\n\n  @Input() enableRedactions = false;\n  @Input() enableICP = false;\n  @Input() multimediaPlayerEnabled = false;\n\n\n  @Input() caseId: string;\n\n  multimediaContent = false;\n  convertibleContent = false;\n  unsupportedContent = false;\n\n  documentTitle: string;\n  showCommentSummary: boolean;\n  annotationSet$: Observable<AnnotationSet | {}>;\n  hasScrollBar: boolean;\n  typeException = false;\n  hasDifferentPageSize$: Observable<boolean>;\n  documentId: string;\n\n  private $subscriptions: Subscription;\n  private prevOffset: number;\n\n  constructor(\n    private store: Store<fromStore.AnnotationSetState>,\n    public readonly toolbarButtons: ToolbarButtonVisibilityService,\n    public readonly toolbarEvents: ToolbarEventService,\n    private readonly api: AnnotationApiService,\n    private readonly commentService: CommentService,\n    private elRef: ElementRef,\n    private cdr: ChangeDetectorRef\n  ) {\n    if (this.annotationApiUrl) {\n      api.annotationApiUrl = this.annotationApiUrl;\n    }\n  }\n\n  ngAfterContentInit() {\n    this.annotationSet$ = this.store.pipe(select(fromAnnoSelectors.getAnnotationSet));\n    this.hasDifferentPageSize$ = this.store.pipe(select(fromDocumentsSelector.getPageDifference));\n    this.setToolbarButtons();\n    this.toolbarEventsOutput.emit(this.toolbarEvents);\n    this.$subscriptions = this.commentService.getUnsavedChanges()\n      .subscribe(changes => this.onCommentChange(changes));\n    this.$subscriptions.add(this.toolbarEvents.getShowCommentSummary()\n      .subscribe(changes => this.showCommentSummary = changes));\n  }\n\n  ngAfterViewChecked(): void {\n    if (this.height && this.viewerHeight !== this.height) {\n      this.viewerHeight = this.height;\n      this.cdr.detectChanges();\n      return;\n    }\n\n    if (!this.height) {\n      const compOffsetTop = this.elRef.nativeElement.getBoundingClientRect().top;\n      const viewerOffsetTop = this.viewerRef.nativeElement.offsetTop;\n      const offset = compOffsetTop + viewerOffsetTop;\n\n      if (this.prevOffset !== offset) {\n        this.viewerHeight = `calc(100vh - ${offset}px)`;\n        this.prevOffset = offset;\n        this.cdr.detectChanges();\n      }\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes.annotationApiUrl) {\n      this.api.annotationApiUrl = this.annotationApiUrl;\n    }\n\n    if (changes.url) {\n      this.toolbarEvents.reset();\n      this.commentService.resetCommentSet();\n      this.documentId = this.extractDMStoreDocId(this.url);\n      this.store.dispatch(new fromDocumentActions.SetDocumentId(this.documentId));\n      if (this.enableAnnotations && !(this.multimediaContent || this.unsupportedContent)) {\n        this.store.dispatch(new fromAnnoActions.LoadAnnotationSet(this.documentId));\n      }\n      if (this.enableRedactions && !(this.multimediaContent || this.unsupportedContent) && this.documentId) {\n        this.store.dispatch(new fromRedactActions.LoadRedactions(this.documentId));\n      }\n      if (this.contentType === 'image') {\n        this.documentTitle = null;\n      }\n    }\n\n    if (changes.contentType) {\n      this.convertibleContent = this.needsConverting();\n      this.multimediaContent = this.isMultimedia();\n      this.unsupportedContent = !this.isSupported();\n    }\n\n    this.setToolbarButtons();\n    this.detectOs();\n    this.typeException = false;\n  }\n\n  ngOnDestroy() {\n    this.$subscriptions.unsubscribe();\n  }\n\n  needsConverting(): boolean {\n    return this.contentType !== null && Object.keys(ConvertibleContentTypes).includes(this.contentType.toUpperCase());\n  }\n\n  isMultimedia(): boolean {\n    return this.contentType !== null && Object.keys(MultimediaContentTypes).includes(this.contentType.toUpperCase());\n  }\n\n  isSupported(): boolean {\n    const supportedTypes = Object.assign({}, MultimediaContentTypes, ConvertibleContentTypes, CoreContentTypes);\n    return this.contentType !== null && Object.keys(supportedTypes).includes(this.contentType.toUpperCase());\n  }\n\n  onMediaLoad(status: ResponseType) {\n    this.mediaLoadStatus.emit(status);\n  }\n\n  setToolbarButtons() {\n    if (this.contentType === CoreContentTypes.PDF || this.needsConverting()) {\n      this.toolbarButtons.setup({\n        ...defaultPdfOptions, showHighlightButton: this.enableAnnotations, showDrawButton: this.enableAnnotations,\n        ...this.toolbarButtonOverrides\n      });\n    } else if (this.contentType === CoreContentTypes.IMAGE) {\n      this.toolbarButtons.setup({\n        ...defaultImageOptions, showDrawButton: this.enableAnnotations,\n        ...this.toolbarButtonOverrides\n      });\n    } else if (this.isMultimedia()) {\n      this.toolbarButtons.setup({\n        ...defaultMultimediaOptions,\n        ...this.toolbarButtonOverrides\n      });\n    } else {\n      this.toolbarButtons.setup({\n        ...defaultUnsupportedOptions,\n        ...this.toolbarButtonOverrides\n      });\n    }\n  }\n\n  onLoadException(exception: ViewerException) {\n    this.viewerException.emit(exception);\n    if (!this.isSupported()) {\n      this.typeException = false;\n    } else {\n      this.typeException = true;\n      this.contentType = null;\n      this.setToolbarButtons();\n    }\n  }\n\n  onCommentChange(changes: boolean) {\n    this.unsavedChanges.emit(changes);\n  }\n\n  onDocumentTitleChange(title: string) {\n    this.documentTitle = title;\n  }\n\n  // If secure mode is enabled (which adds \"documentsv2\" to the documentId), get rid of it\n  private extractDMStoreDocId(url: string): string {\n    url = url.includes('/documents/') ? url.split('/documents/')[1] : url;\n    url = url.includes('/documentsv2/') ? url.split('/documentsv2/')[1] : url;\n    return url.replace('/binary', '');\n  }\n\n  detectOs() {\n    this.hasScrollBar = window.navigator.userAgent.indexOf('Win') !== -1;\n  }\n}\n"]}
|
|
@@ -3,7 +3,7 @@
|
|
|
3
3
|
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
|
|
4
4
|
*/
|
|
5
5
|
import * as tslib_1 from "tslib";
|
|
6
|
-
import { Component, ElementRef, EventEmitter, Input, Output, ViewChild, } from '@angular/core';
|
|
6
|
+
import { Component, ElementRef, EventEmitter, HostListener, Input, Output, ViewChild, } from '@angular/core';
|
|
7
7
|
import { PrintService } from '../../print.service';
|
|
8
8
|
import { ToolbarEventService } from '../../toolbar/toolbar-event.service';
|
|
9
9
|
import { ResponseType, ViewerException } from '../viewer-exception.model';
|
|
@@ -11,6 +11,8 @@ import { ViewerUtilService } from '../viewer-util.service';
|
|
|
11
11
|
import { ToolbarButtonVisibilityService } from '../../toolbar/toolbar-button-visibility.service';
|
|
12
12
|
import { Store } from '@ngrx/store';
|
|
13
13
|
import * as fromDocument from '../../store/actions/document.actions';
|
|
14
|
+
import * as fromAnnotationActions from '../../store/actions/annotation.actions';
|
|
15
|
+
import { ViewerEventService } from '../viewer-event.service';
|
|
14
16
|
export class ImageViewerComponent {
|
|
15
17
|
/**
|
|
16
18
|
* @param {?} store
|
|
@@ -18,13 +20,15 @@ export class ImageViewerComponent {
|
|
|
18
20
|
* @param {?} viewerUtilService
|
|
19
21
|
* @param {?} toolbarEvents
|
|
20
22
|
* @param {?} toolbarButtons
|
|
23
|
+
* @param {?} viewerEvents
|
|
21
24
|
*/
|
|
22
|
-
constructor(store, printService, viewerUtilService, toolbarEvents, toolbarButtons) {
|
|
25
|
+
constructor(store, printService, viewerUtilService, toolbarEvents, toolbarButtons, viewerEvents) {
|
|
23
26
|
this.store = store;
|
|
24
27
|
this.printService = printService;
|
|
25
28
|
this.viewerUtilService = viewerUtilService;
|
|
26
29
|
this.toolbarEvents = toolbarEvents;
|
|
27
30
|
this.toolbarButtons = toolbarButtons;
|
|
31
|
+
this.viewerEvents = viewerEvents;
|
|
28
32
|
this.mediaLoadStatus = new EventEmitter();
|
|
29
33
|
this.imageViewerException = new EventEmitter();
|
|
30
34
|
this.rotation = 0;
|
|
@@ -64,6 +68,22 @@ export class ImageViewerComponent {
|
|
|
64
68
|
*/
|
|
65
69
|
toggle => this.showCommentsPanel = toggle)));
|
|
66
70
|
}
|
|
71
|
+
/**
|
|
72
|
+
* @param {?} event
|
|
73
|
+
* @return {?}
|
|
74
|
+
*/
|
|
75
|
+
onImageViewerClick(event) {
|
|
76
|
+
/** @type {?} */
|
|
77
|
+
const classNme = ((/** @type {?} */ (event.target))).className;
|
|
78
|
+
if (classNme.startsWith('pageContainer')) {
|
|
79
|
+
this.store.dispatch(new fromAnnotationActions.SelectedAnnotation({
|
|
80
|
+
annotationId: '',
|
|
81
|
+
selected: false,
|
|
82
|
+
editable: false,
|
|
83
|
+
}));
|
|
84
|
+
this.viewerEvents.clearCtxToolbar();
|
|
85
|
+
}
|
|
86
|
+
}
|
|
67
87
|
/**
|
|
68
88
|
* @return {?}
|
|
69
89
|
*/
|
|
@@ -237,7 +257,7 @@ export class ImageViewerComponent {
|
|
|
237
257
|
ImageViewerComponent.decorators = [
|
|
238
258
|
{ type: Component, args: [{
|
|
239
259
|
selector: 'mv-image-viewer',
|
|
240
|
-
template: "<mv-comment-set-header [ngClass]=\"{'show-comments-panel': showCommentsPanel}\"\n [showCommentSummary]=\"toolbarButtons.showCommentSummary\"\n (showCommentSummaryDialog)=\"toggleCommentsSummary()\">\n</mv-comment-set-header>\n<div mvGrabNDrag [dragX]=\"imageContainer\" [dragEnabled]=\"enableGrabNDrag\"\n id=\"viewer-wrapper\"\n [ngStyle]=\"{ height: height }\"\n [ngClass]=\"{ 'grabNDrag': enableGrabNDrag }\"\n *ngIf=\"url && !errorMessage\">\n <div #imageContainer
|
|
260
|
+
template: "<mv-comment-set-header [ngClass]=\"{'show-comments-panel': showCommentsPanel}\"\n [showCommentSummary]=\"toolbarButtons.showCommentSummary\"\n (showCommentSummaryDialog)=\"toggleCommentsSummary()\">\n</mv-comment-set-header>\n<div mvGrabNDrag [dragX]=\"imageContainer\" [dragEnabled]=\"enableGrabNDrag\"\n id=\"viewer-wrapper\"\n [ngStyle]=\"{ height: height }\"\n [ngClass]=\"{ 'grabNDrag': enableGrabNDrag }\"\n *ngIf=\"url && !errorMessage\">\n <div #imageContainer id=\"image-container\"\n [ngClass]=\"{ 'image-container': true, 'annotations': enableAnnotations, 'show-comments-panel': showCommentsPanel }\"\n [style.height.px]=\"imageHeight\">\n <img #img\n [src]=\"url\"\n [ngClass]=\"'rot' + rotation\"\n (error)=\"onLoadError(url)\"\n (load)=\"onLoad(img)\"/>\n <mv-redactions *ngIf=\"(toolbarEvents.redactionMode | async);else annotationTemplate\"\n [zoom]=\"zoom\"\n [rotate]=\"rotation\"\n ></mv-redactions>\n <ng-template #annotationTemplate>\n <mv-metadata-layer *ngIf=\"enableAnnotations && annotationSet\"\n [zoom]=\"zoom\"\n [rotate]=\"rotation\">\n </mv-metadata-layer>\n </ng-template>\n </div>\n\n <div class=\"comments\" [style.height.px]=\"imageHeight\">\n <mv-comment-set *ngIf=\"enableAnnotations && annotationSet && !(toolbarEvents.redactionMode | async)\"\n [annotationSet]=\"annotationSet\"\n [zoom]=\"zoom\"\n [rotate]=\"rotation\"\n [height]=\"imageHeight\">\n </mv-comment-set>\n </div>\n</div>\n"
|
|
241
261
|
}] }
|
|
242
262
|
];
|
|
243
263
|
/** @nocollapse */
|
|
@@ -246,7 +266,8 @@ ImageViewerComponent.ctorParameters = () => [
|
|
|
246
266
|
{ type: PrintService },
|
|
247
267
|
{ type: ViewerUtilService },
|
|
248
268
|
{ type: ToolbarEventService },
|
|
249
|
-
{ type: ToolbarButtonVisibilityService }
|
|
269
|
+
{ type: ToolbarButtonVisibilityService },
|
|
270
|
+
{ type: ViewerEventService }
|
|
250
271
|
];
|
|
251
272
|
ImageViewerComponent.propDecorators = {
|
|
252
273
|
url: [{ type: Input }],
|
|
@@ -256,7 +277,8 @@ ImageViewerComponent.propDecorators = {
|
|
|
256
277
|
height: [{ type: Input }],
|
|
257
278
|
mediaLoadStatus: [{ type: Output }],
|
|
258
279
|
imageViewerException: [{ type: Output }],
|
|
259
|
-
img: [{ type: ViewChild, args: ['img',] }]
|
|
280
|
+
img: [{ type: ViewChild, args: ['img',] }],
|
|
281
|
+
onImageViewerClick: [{ type: HostListener, args: ['mousedown', ['$event'],] }]
|
|
260
282
|
};
|
|
261
283
|
if (false) {
|
|
262
284
|
/** @type {?} */
|
|
@@ -327,5 +349,10 @@ if (false) {
|
|
|
327
349
|
ImageViewerComponent.prototype.toolbarEvents;
|
|
328
350
|
/** @type {?} */
|
|
329
351
|
ImageViewerComponent.prototype.toolbarButtons;
|
|
352
|
+
/**
|
|
353
|
+
* @type {?}
|
|
354
|
+
* @private
|
|
355
|
+
*/
|
|
356
|
+
ImageViewerComponent.prototype.viewerEvents;
|
|
330
357
|
}
|
|
331
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"image-viewer.component.js","sourceRoot":"ng://@hmcts/media-viewer/","sources":["lib/viewers/image-viewer/image-viewer.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  SimpleChanges,\n  ViewChild,\n} from '@angular/core';\nimport { Subscription } from 'rxjs';\nimport { PrintService } from '../../print.service';\nimport { AnnotationSet } from '../../annotations/annotation-set/annotation-set.model';\nimport { ToolbarEventService } from '../../toolbar/toolbar-event.service';\nimport { ResponseType, ViewerException } from '../viewer-exception.model';\nimport { ViewerUtilService } from '../viewer-util.service';\nimport { ToolbarButtonVisibilityService } from '../../toolbar/toolbar-button-visibility.service';\nimport { Store } from '@ngrx/store';\nimport * as fromStore from '../../store/reducers/reducers';\nimport * as fromDocument from '../../store/actions/document.actions';\n\n@Component({\n    selector: 'mv-image-viewer',\n    templateUrl: './image-viewer.component.html'\n})\nexport class ImageViewerComponent implements OnInit, OnDestroy, OnChanges {\n\n  @Input() url: string;\n  @Input() downloadFileName: string;\n\n  @Input() enableAnnotations: boolean;\n  @Input() annotationSet: AnnotationSet | null;\n\n  @Input() height: string;\n\n  @Output() mediaLoadStatus = new EventEmitter<ResponseType>();\n  @Output() imageViewerException = new EventEmitter<ViewerException>();\n\n  errorMessage: string;\n\n  @ViewChild('img') img: ElementRef;\n  rotation = 0;\n  zoom = 1;\n\n  private subscriptions: Subscription[] = [];\n  private viewerException: ViewerException;\n  private response: Subscription;\n\n  showCommentsPanel: boolean;\n  enableGrabNDrag = false;\n  imageHeight: number;\n  imageWidth: number;\n  imageLeft: number;\n  imageTop: number;\n\n  constructor(\n    private store: Store<fromStore.AnnotationSetState>,\n    private readonly printService: PrintService,\n    private readonly viewerUtilService: ViewerUtilService,\n    public readonly toolbarEvents: ToolbarEventService,\n    public readonly toolbarButtons: ToolbarButtonVisibilityService\n  ) { }\n\n  ngOnInit(): void {\n    this.subscriptions.push(\n      this.toolbarEvents.rotateSubject.subscribe(rotation => this.rotateImage(rotation)),\n      this.toolbarEvents.zoomSubject.subscribe(zoom => this.setZoom(zoom)),\n      this.toolbarEvents.stepZoomSubject.subscribe(zoom => this.stepZoom(zoom)),\n      this.toolbarEvents.printSubject.subscribe(() => this.printService.printDocumentNatively(this.url)),\n      this.toolbarEvents.downloadSubject.subscribe(() => this.download()),\n      this.toolbarEvents.grabNDrag.subscribe(grabNDrag => this.enableGrabNDrag = grabNDrag),\n      this.toolbarEvents.commentsPanelVisible.subscribe(toggle => this.showCommentsPanel = toggle)\n    );\n  }\n\n  ngOnDestroy(): void {\n    this.subscriptions.filter(subscription => !subscription.closed)\n      .forEach(subscription => subscription.unsubscribe());\n    if (this.response) {\n      this.response.unsubscribe();\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes.url) {\n      this.errorMessage = null;\n      this.toolbarEvents.reset();\n    }\n  }\n\n  private rotateImage(rotation: number) {\n    this.rotation = (this.rotation + rotation) % 360;\n    this.initAnnoPage(this.img.nativeElement);\n  }\n\n  private async setZoom(zoomFactor: number) {\n    if (!isNaN(zoomFactor)) {\n      await this.setZoomValue(this.calculateZoomValue(zoomFactor));\n      this.img.nativeElement.width = this.img.nativeElement.naturalWidth * this.zoom;\n      this.initAnnoPage(this.img.nativeElement);\n    }\n  }\n\n  private async stepZoom(zoomFactor: number) {\n    if (!isNaN(zoomFactor)) {\n      await this.setZoomValue(this.calculateZoomValue(this.zoom, zoomFactor));\n      this.img.nativeElement.width = this.img.nativeElement.naturalWidth * this.zoom;\n      this.initAnnoPage(this.img.nativeElement);\n    }\n  }\n\n  private download() {\n    const a = document.createElement('a');\n    document.body.appendChild(a);\n    a.setAttribute('style', 'display: none');\n    a.href = this.url;\n    a.download = this.downloadFileName;\n    a.click();\n    a.remove();\n  }\n\n  // the returned promise is a work-around\n  setZoomValue(zoomValue) {\n    return new Promise((resolve) => {\n      this.zoom = zoomValue;\n      this.toolbarEvents.zoomValueSubject.next(zoomValue);\n      resolve(true);\n    });\n  }\n\n  calculateZoomValue(zoomValue, increment = 0) {\n    const newZoomValue = zoomValue + increment;\n    if (newZoomValue > 5) { return 5; }\n    if (newZoomValue < 0.1) { return 0.1; }\n    return +newZoomValue.toFixed(2);\n  }\n\n  onLoadError(url) {\n    this.response = this.viewerUtilService.validateFile(url)\n      .subscribe(\n      next => next,\n      error => {\n        this.viewerException = new ViewerException(error.name,\n          {httpResponseCode: error.status, message: error.message});\n      });\n\n    this.errorMessage = `Could not load the image \"${this.url}\"`;\n    this.mediaLoadStatus.emit(ResponseType.FAILURE);\n    this.imageViewerException.emit(this.viewerException);\n  }\n\n  onLoad(img: any) {\n    this.mediaLoadStatus.emit(ResponseType.SUCCESS);\n    this.initAnnoPage(img);\n  }\n\n  initAnnoPage(img: any) {\n    this.imageHeight = this.rotation % 180 !== 0 ? img.offsetWidth : img.offsetHeight;\n    this.imageWidth = this.rotation % 180 !== 0 ? img.offsetHeight : img.offsetWidth;\n    this.imageLeft = this.rotation % 180 !== 0 ? img.offsetTop : img.offsetLeft;\n    this.imageTop = this.rotation % 180 !== 0 ? img.offsetLeft : img.offsetTop;\n    const payload: any = [{\n      div: {\n        scrollHeight: this.imageHeight,\n        scrollWidth: this.imageWidth,\n        offsetLeft: this.imageLeft,\n      },\n      pageNumber: 1,\n      scale: this.zoom,\n      rotation: this.rotation,\n      id: 1\n    }];\n\n    this.store.dispatch(new fromDocument.AddPages(payload));\n  }\n\n  toggleCommentsSummary() {\n    this.toolbarEvents.toggleCommentsSummary(!this.toolbarEvents.showCommentSummary.getValue());\n  }\n}\n"]}
|
|
358
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"image-viewer.component.js","sourceRoot":"ng://@hmcts/media-viewer/","sources":["lib/viewers/image-viewer/image-viewer.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ElementRef,\n  EventEmitter,\n  HostListener,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  SimpleChanges,\n  ViewChild,\n} from '@angular/core';\nimport { Subscription } from 'rxjs';\nimport { PrintService } from '../../print.service';\nimport { AnnotationSet } from '../../annotations/annotation-set/annotation-set.model';\nimport { ToolbarEventService } from '../../toolbar/toolbar-event.service';\nimport { ResponseType, ViewerException } from '../viewer-exception.model';\nimport { ViewerUtilService } from '../viewer-util.service';\nimport { ToolbarButtonVisibilityService } from '../../toolbar/toolbar-button-visibility.service';\nimport { Store } from '@ngrx/store';\nimport * as fromStore from '../../store/reducers/reducers';\nimport * as fromDocument from '../../store/actions/document.actions';\nimport * as fromAnnotationActions from '../../store/actions/annotation.actions';\nimport { ViewerEventService } from '../viewer-event.service';\n\n@Component({\n  selector: 'mv-image-viewer',\n  templateUrl: './image-viewer.component.html'\n})\nexport class ImageViewerComponent implements OnInit, OnDestroy, OnChanges {\n\n  @Input() url: string;\n  @Input() downloadFileName: string;\n\n  @Input() enableAnnotations: boolean;\n  @Input() annotationSet: AnnotationSet | null;\n\n  @Input() height: string;\n\n  @Output() mediaLoadStatus = new EventEmitter<ResponseType>();\n  @Output() imageViewerException = new EventEmitter<ViewerException>();\n\n  errorMessage: string;\n\n  @ViewChild('img') img: ElementRef;\n  rotation = 0;\n  zoom = 1;\n\n  private subscriptions: Subscription[] = [];\n  private viewerException: ViewerException;\n  private response: Subscription;\n\n  showCommentsPanel: boolean;\n  enableGrabNDrag = false;\n  imageHeight: number;\n  imageWidth: number;\n  imageLeft: number;\n  imageTop: number;\n\n  constructor(\n    private store: Store<fromStore.AnnotationSetState>,\n    private readonly printService: PrintService,\n    private readonly viewerUtilService: ViewerUtilService,\n    public readonly toolbarEvents: ToolbarEventService,\n    public readonly toolbarButtons: ToolbarButtonVisibilityService,\n    private viewerEvents: ViewerEventService,\n  ) { }\n\n  ngOnInit(): void {\n    this.subscriptions.push(\n      this.toolbarEvents.rotateSubject.subscribe(rotation => this.rotateImage(rotation)),\n      this.toolbarEvents.zoomSubject.subscribe(zoom => this.setZoom(zoom)),\n      this.toolbarEvents.stepZoomSubject.subscribe(zoom => this.stepZoom(zoom)),\n      this.toolbarEvents.printSubject.subscribe(() => this.printService.printDocumentNatively(this.url)),\n      this.toolbarEvents.downloadSubject.subscribe(() => this.download()),\n      this.toolbarEvents.grabNDrag.subscribe(grabNDrag => this.enableGrabNDrag = grabNDrag),\n      this.toolbarEvents.commentsPanelVisible.subscribe(toggle => this.showCommentsPanel = toggle)\n    );\n  }\n\n  @HostListener('mousedown', ['$event'])\n  onImageViewerClick(event: MouseEvent) {\n    const classNme = (event.target as Element).className;\n    if (classNme.startsWith('pageContainer')) {\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\n  ngOnDestroy(): void {\n    this.subscriptions.filter(subscription => !subscription.closed)\n      .forEach(subscription => subscription.unsubscribe());\n    if (this.response) {\n      this.response.unsubscribe();\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes.url) {\n      this.errorMessage = null;\n      this.toolbarEvents.reset();\n    }\n  }\n\n  private rotateImage(rotation: number) {\n    this.rotation = (this.rotation + rotation) % 360;\n    this.initAnnoPage(this.img.nativeElement);\n  }\n\n  private async setZoom(zoomFactor: number) {\n    if (!isNaN(zoomFactor)) {\n      await this.setZoomValue(this.calculateZoomValue(zoomFactor));\n      this.img.nativeElement.width = this.img.nativeElement.naturalWidth * this.zoom;\n      this.initAnnoPage(this.img.nativeElement);\n    }\n  }\n\n  private async stepZoom(zoomFactor: number) {\n    if (!isNaN(zoomFactor)) {\n      await this.setZoomValue(this.calculateZoomValue(this.zoom, zoomFactor));\n      this.img.nativeElement.width = this.img.nativeElement.naturalWidth * this.zoom;\n      this.initAnnoPage(this.img.nativeElement);\n    }\n  }\n\n  private download() {\n    const a = document.createElement('a');\n    document.body.appendChild(a);\n    a.setAttribute('style', 'display: none');\n    a.href = this.url;\n    a.download = this.downloadFileName;\n    a.click();\n    a.remove();\n  }\n\n  // the returned promise is a work-around\n  setZoomValue(zoomValue) {\n    return new Promise((resolve) => {\n      this.zoom = zoomValue;\n      this.toolbarEvents.zoomValueSubject.next(zoomValue);\n      resolve(true);\n    });\n  }\n\n  calculateZoomValue(zoomValue, increment = 0) {\n    const newZoomValue = zoomValue + increment;\n    if (newZoomValue > 5) { return 5; }\n    if (newZoomValue < 0.1) { return 0.1; }\n    return +newZoomValue.toFixed(2);\n  }\n\n  onLoadError(url) {\n    this.response = this.viewerUtilService.validateFile(url)\n      .subscribe(\n        next => next,\n        error => {\n          this.viewerException = new ViewerException(error.name,\n            { httpResponseCode: error.status, message: error.message });\n        });\n\n    this.errorMessage = `Could not load the image \"${this.url}\"`;\n    this.mediaLoadStatus.emit(ResponseType.FAILURE);\n    this.imageViewerException.emit(this.viewerException);\n  }\n\n  onLoad(img: any) {\n    this.mediaLoadStatus.emit(ResponseType.SUCCESS);\n    this.initAnnoPage(img);\n  }\n\n  initAnnoPage(img: any) {\n    this.imageHeight = this.rotation % 180 !== 0 ? img.offsetWidth : img.offsetHeight;\n    this.imageWidth = this.rotation % 180 !== 0 ? img.offsetHeight : img.offsetWidth;\n    this.imageLeft = this.rotation % 180 !== 0 ? img.offsetTop : img.offsetLeft;\n    this.imageTop = this.rotation % 180 !== 0 ? img.offsetLeft : img.offsetTop;\n    const payload: any = [{\n      div: {\n        scrollHeight: this.imageHeight,\n        scrollWidth: this.imageWidth,\n        offsetLeft: this.imageLeft,\n      },\n      pageNumber: 1,\n      scale: this.zoom,\n      rotation: this.rotation,\n      id: 1\n    }];\n\n    this.store.dispatch(new fromDocument.AddPages(payload));\n  }\n\n  toggleCommentsSummary() {\n    this.toolbarEvents.toggleCommentsSummary(!this.toolbarEvents.showCommentSummary.getValue());\n  }\n}\n"]}
|