@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.
Files changed (38) hide show
  1. package/bundles/hmcts-media-viewer.umd.js +4890 -4755
  2. package/bundles/hmcts-media-viewer.umd.js.map +1 -1
  3. package/bundles/hmcts-media-viewer.umd.min.js +1 -1
  4. package/bundles/hmcts-media-viewer.umd.min.js.map +1 -1
  5. package/esm2015/hmcts-media-viewer.js +20 -20
  6. package/esm2015/lib/annotations/annotation-set/annotation-create/box-highlight-create/box-highlight-create.component.js +8 -2
  7. package/esm2015/lib/icp/icp-update.service.js +22 -40
  8. package/esm2015/lib/icp/icp.events.js +20 -0
  9. package/esm2015/lib/icp/icp.interfaces.js +3 -1
  10. package/esm2015/lib/icp/socket.service.js +133 -43
  11. package/esm2015/lib/media-viewer.component.js +2 -2
  12. package/esm2015/lib/viewers/image-viewer/image-viewer.component.js +33 -6
  13. package/esm2015/lib/viewers/pdf-viewer/pdf-viewer.component.js +11 -2
  14. package/esm5/hmcts-media-viewer.js +20 -20
  15. package/esm5/lib/annotations/annotation-set/annotation-create/box-highlight-create/box-highlight-create.component.js +8 -2
  16. package/esm5/lib/icp/icp-update.service.js +23 -40
  17. package/esm5/lib/icp/icp.events.js +20 -0
  18. package/esm5/lib/icp/icp.interfaces.js +3 -1
  19. package/esm5/lib/icp/socket.service.js +143 -45
  20. package/esm5/lib/media-viewer.component.js +2 -2
  21. package/esm5/lib/viewers/image-viewer/image-viewer.component.js +36 -6
  22. package/esm5/lib/viewers/pdf-viewer/pdf-viewer.component.js +10 -2
  23. package/fesm2015/hmcts-media-viewer.js +4198 -4074
  24. package/fesm2015/hmcts-media-viewer.js.map +1 -1
  25. package/fesm5/hmcts-media-viewer.js +4873 -4738
  26. package/fesm5/hmcts-media-viewer.js.map +1 -1
  27. package/hmcts-media-viewer-v2.7.23.tgz +0 -0
  28. package/hmcts-media-viewer.d.ts +19 -19
  29. package/hmcts-media-viewer.metadata.json +1 -1
  30. package/lib/annotations/annotation-set/annotation-create/box-highlight-create/box-highlight-create.component.d.ts +4 -3
  31. package/lib/icp/icp-update.service.d.ts +0 -9
  32. package/lib/icp/icp.events.d.ts +13 -0
  33. package/lib/icp/icp.interfaces.d.ts +1 -0
  34. package/lib/icp/socket.service.d.ts +13 -4
  35. package/lib/viewers/image-viewer/image-viewer.component.d.ts +4 -1
  36. package/lib/viewers/pdf-viewer/pdf-viewer.component.d.ts +3 -1
  37. package/package.json +1 -1
  38. 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, Observable } from 'rxjs';
7
- import socketio from 'socket.io-client/dist/socket.io.js';
6
+ import { BehaviorSubject, of, Subject } from 'rxjs';
7
+ import { IcpEvents } from './icp.events';
8
8
  var SocketService = /** @class */ (function () {
9
9
  function SocketService() {
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 {?}
@@ -19,22 +25,63 @@ var SocketService = /** @class */ (function () {
19
25
  this.subscription.unsubscribe();
20
26
  };
21
27
  /**
28
+ * @param {?} url
22
29
  * @return {?}
23
30
  */
24
31
  SocketService.prototype.connect = /**
32
+ * @param {?} url
25
33
  * @return {?}
26
34
  */
27
- function () {
35
+ function (url) {
28
36
  var _this = this;
29
- this.socket = this.getSocketClient();
30
- this.socket.on('connect', (/**
31
- * @return {?}
32
- */
33
- function () { return _this.connected$.next(true); }));
34
- this.socket.on('disconnect', (/**
37
+ return this.getSocketClient(url).subscribe((/**
38
+ * @param {?} socket
35
39
  * @return {?}
36
40
  */
37
- function () { return _this.connected$.next(false); }));
41
+ function (socket) {
42
+ socket.onopen = (/**
43
+ * @param {?} event
44
+ * @return {?}
45
+ */
46
+ function (event) {
47
+ _this.connected$.next(true);
48
+ });
49
+ socket.onmessage = (/**
50
+ * @param {?} event
51
+ * @return {?}
52
+ */
53
+ function (event) {
54
+ console.log('onmessage');
55
+ /** @type {?} */
56
+ var eventData = JSON.parse(event.data);
57
+ if (eventData.data && eventData.data.eventName) {
58
+ _this.messageEventHandller(eventData.data.eventName, eventData.data.data);
59
+ }
60
+ });
61
+ socket.onerror = (/**
62
+ * @param {?} event
63
+ * @return {?}
64
+ */
65
+ function (event) {
66
+ console.log('onerror');
67
+ });
68
+ socket.onclose = (/**
69
+ * @param {?} event
70
+ * @return {?}
71
+ */
72
+ function (event) {
73
+ console.log('onclose');
74
+ });
75
+ }));
76
+ };
77
+ /**
78
+ * @return {?}
79
+ */
80
+ SocketService.prototype.connected = /**
81
+ * @return {?}
82
+ */
83
+ function () {
84
+ return this.connected$.asObservable();
38
85
  };
39
86
  /**
40
87
  * @param {?} session
@@ -45,16 +92,7 @@ var SocketService = /** @class */ (function () {
45
92
  * @return {?}
46
93
  */
47
94
  function (session) {
48
- var _this = this;
49
- this.subscription = this.connected$.subscribe((/**
50
- * @param {?} connected
51
- * @return {?}
52
- */
53
- function (connected) {
54
- if (connected) {
55
- _this.socket.emit('join', session);
56
- }
57
- }));
95
+ this.emit(IcpEvents.SESSION_JOIN, session);
58
96
  };
59
97
  /**
60
98
  * @param {?} session
@@ -65,7 +103,7 @@ var SocketService = /** @class */ (function () {
65
103
  * @return {?}
66
104
  */
67
105
  function (session) {
68
- this.socket.emit('leave', session);
106
+ this.emit(IcpEvents.SESSION_LEAVE, session);
69
107
  this.subscription.unsubscribe();
70
108
  };
71
109
  /**
@@ -79,7 +117,11 @@ var SocketService = /** @class */ (function () {
79
117
  * @return {?}
80
118
  */
81
119
  function (event, data) {
82
- this.socket.emit(event, data);
120
+ this.socket.send(JSON.stringify({
121
+ type: 'event',
122
+ event: event,
123
+ data: data
124
+ }));
83
125
  };
84
126
  /**
85
127
  * @param {?} event
@@ -90,35 +132,79 @@ var SocketService = /** @class */ (function () {
90
132
  * @return {?}
91
133
  */
92
134
  function (event) {
93
- var _this = this;
94
- return new Observable((/**
95
- * @param {?} observer
96
- * @return {?}
97
- */
98
- function (observer) {
99
- _this.socket.on(event, (/**
100
- * @param {?} data
101
- * @return {?}
102
- */
103
- function (data) {
104
- observer.next(data);
105
- }));
106
- return (/**
107
- * @return {?}
108
- */
109
- function () { return _this.socket.off(event); });
110
- }));
135
+ switch (event) {
136
+ case IcpEvents.SESSION_JOINED: {
137
+ return this.sessionJoined$.asObservable();
138
+ }
139
+ case IcpEvents.PRESENTER_UPDATED: {
140
+ return this.presenterUpdated$.asObservable();
141
+ }
142
+ case IcpEvents.CLIENT_DISCONNECTED: {
143
+ return this.clientDisconnected$.asObservable();
144
+ }
145
+ case IcpEvents.PARTICIPANTS_UPDATED: {
146
+ return this.participantUpdated$.asObservable();
147
+ }
148
+ case IcpEvents.NEW_PARTICIPANT_JOINED: {
149
+ return this.newParticipantJoined$.asObservable();
150
+ }
151
+ case IcpEvents.SCREEN_UPDATED: {
152
+ return this.screenUpdated$.asObservable();
153
+ }
154
+ default: {
155
+ break;
156
+ }
157
+ }
158
+ };
159
+ /**
160
+ * @param {?} eventName
161
+ * @param {?} data
162
+ * @return {?}
163
+ */
164
+ SocketService.prototype.messageEventHandller = /**
165
+ * @param {?} eventName
166
+ * @param {?} data
167
+ * @return {?}
168
+ */
169
+ function (eventName, data) {
170
+ switch (eventName) {
171
+ case IcpEvents.SESSION_JOINED: {
172
+ this.sessionJoined$.next(data);
173
+ break;
174
+ }
175
+ case IcpEvents.PRESENTER_UPDATED: {
176
+ this.presenterUpdated$.next(data);
177
+ break;
178
+ }
179
+ case IcpEvents.CLIENT_DISCONNECTED: {
180
+ this.clientDisconnected$.next();
181
+ break;
182
+ }
183
+ case IcpEvents.PARTICIPANTS_UPDATED: {
184
+ this.participantUpdated$.next(data);
185
+ break;
186
+ }
187
+ case IcpEvents.NEW_PARTICIPANT_JOINED: {
188
+ this.newParticipantJoined$.next();
189
+ break;
190
+ }
191
+ case IcpEvents.SCREEN_UPDATED: {
192
+ this.screenUpdated$.next(data);
193
+ break;
194
+ }
195
+ }
111
196
  };
112
197
  /**
198
+ * @param {?} url
113
199
  * @return {?}
114
200
  */
115
201
  SocketService.prototype.getSocketClient = /**
202
+ * @param {?} url
116
203
  * @return {?}
117
204
  */
118
- function () {
119
- return socketio('/', {
120
- path: '/icp/socket.io', agent: true
121
- });
205
+ function (url) {
206
+ this.socket = new WebSocket(url, 'json.webpubsub.azure.v1');
207
+ return of(this.socket);
122
208
  };
123
209
  SocketService.decorators = [
124
210
  { type: Injectable }
@@ -138,5 +224,17 @@ if (false) {
138
224
  SocketService.prototype.subscription;
139
225
  /** @type {?} */
140
226
  SocketService.prototype.connected$;
227
+ /** @type {?} */
228
+ SocketService.prototype.sessionJoined$;
229
+ /** @type {?} */
230
+ SocketService.prototype.presenterUpdated$;
231
+ /** @type {?} */
232
+ SocketService.prototype.clientDisconnected$;
233
+ /** @type {?} */
234
+ SocketService.prototype.participantUpdated$;
235
+ /** @type {?} */
236
+ SocketService.prototype.newParticipantJoined$;
237
+ /** @type {?} */
238
+ SocketService.prototype.screenUpdated$;
141
239
  }
142
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic29ja2V0LnNlcnZpY2UuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9AaG1jdHMvbWVkaWEtdmlld2VyLyIsInNvdXJjZXMiOlsibGliL2ljcC9zb2NrZXQuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7O0FBQUEsT0FBTyxFQUFFLFVBQVUsRUFBYSxNQUFNLGVBQWUsQ0FBQztBQUN0RCxPQUFPLEVBQUUsZUFBZSxFQUFFLFVBQVUsRUFBZ0IsTUFBTSxNQUFNLENBQUM7QUFDakUsT0FBTyxRQUFRLE1BQU0sb0NBQW9DLENBQUM7QUFFMUQ7SUFRRTtRQUZBLGVBQVUsR0FBRyxJQUFJLGVBQWUsQ0FBVSxLQUFLLENBQUMsQ0FBQztJQUVsQyxDQUFDOzs7O0lBRWhCLG1DQUFXOzs7SUFBWDtRQUNFLElBQUksQ0FBQyxZQUFZLENBQUMsV0FBVyxFQUFFLENBQUM7SUFDbEMsQ0FBQzs7OztJQUVELCtCQUFPOzs7SUFBUDtRQUFBLGlCQUlDO1FBSEMsSUFBSSxDQUFDLE1BQU0sR0FBRyxJQUFJLENBQUMsZUFBZSxFQUFFLENBQUM7UUFDckMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUMsU0FBUzs7O1FBQUUsY0FBTSxPQUFBLEtBQUksQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxFQUExQixDQUEwQixFQUFDLENBQUM7UUFDNUQsSUFBSSxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUMsWUFBWTs7O1FBQUUsY0FBTSxPQUFBLEtBQUksQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxFQUEzQixDQUEyQixFQUFDLENBQUM7SUFDbEUsQ0FBQzs7Ozs7SUFFRCw0QkFBSTs7OztJQUFKLFVBQUssT0FBTztRQUFaLGlCQU1DO1FBTEMsSUFBSSxDQUFDLFlBQVksR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLFNBQVM7Ozs7UUFBQyxVQUFBLFNBQVM7WUFDckQsSUFBSSxTQUFTLEVBQUU7Z0JBQ2IsS0FBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsTUFBTSxFQUFFLE9BQU8sQ0FBQyxDQUFDO2FBQ25DO1FBQ0gsQ0FBQyxFQUFDLENBQUM7SUFDTCxDQUFDOzs7OztJQUVELDZCQUFLOzs7O0lBQUwsVUFBTSxPQUFPO1FBQ1gsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsT0FBTyxFQUFFLE9BQU8sQ0FBQyxDQUFDO1FBQ25DLElBQUksQ0FBQyxZQUFZLENBQUMsV0FBVyxFQUFFLENBQUM7SUFDbEMsQ0FBQzs7Ozs7O0lBRUQsNEJBQUk7Ozs7O0lBQUosVUFBSyxLQUFhLEVBQUUsSUFBUztRQUMzQixJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxLQUFLLEVBQUUsSUFBSSxDQUFDLENBQUM7SUFDaEMsQ0FBQzs7Ozs7SUFFRCw4QkFBTTs7OztJQUFOLFVBQU8sS0FBYTtRQUFwQixpQkFPQztRQU5DLE9BQU8sSUFBSSxVQUFVOzs7O1FBQUUsVUFBQSxRQUFRO1lBQzdCLEtBQUksQ0FBQyxNQUFNLENBQUMsRUFBRSxDQUFDLEtBQUs7Ozs7WUFBRSxVQUFBLElBQUk7Z0JBQ3hCLFFBQVEsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7WUFDdEIsQ0FBQyxFQUFDLENBQUM7WUFDSDs7O1lBQU8sY0FBTSxPQUFBLEtBQUksQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxFQUF0QixDQUFzQixFQUFDO1FBQ3RDLENBQUMsRUFBQyxDQUFDO0lBQ0wsQ0FBQzs7OztJQUVELHVDQUFlOzs7SUFBZjtRQUNFLE9BQU8sUUFBUSxDQUFDLEdBQUcsRUFBRTtZQUNuQixJQUFJLEVBQUUsZ0JBQWdCLEVBQUUsS0FBSyxFQUFFLElBQUk7U0FDcEMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQzs7Z0JBbERGLFVBQVU7Ozs7SUFtRFgsb0JBQUM7Q0FBQSxBQW5ERCxJQW1EQztTQWxEWSxhQUFhOzs7Ozs7SUFFeEIsK0JBQW9COztJQUNwQixxQ0FBMkI7O0lBRTNCLG1DQUFpRCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUsIE9uRGVzdHJveSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQmVoYXZpb3JTdWJqZWN0LCBPYnNlcnZhYmxlLCBTdWJzY3JpcHRpb24gfSBmcm9tICdyeGpzJztcbmltcG9ydCBzb2NrZXRpbyBmcm9tICdzb2NrZXQuaW8tY2xpZW50L2Rpc3Qvc29ja2V0LmlvLmpzJztcblxuQEluamVjdGFibGUoKVxuZXhwb3J0IGNsYXNzIFNvY2tldFNlcnZpY2UgaW1wbGVtZW50cyBPbkRlc3Ryb3kge1xuXG4gIHByaXZhdGUgc29ja2V0OiBhbnk7XG4gIHN1YnNjcmlwdGlvbjogU3Vic2NyaXB0aW9uO1xuXG4gIGNvbm5lY3RlZCQgPSBuZXcgQmVoYXZpb3JTdWJqZWN0PGJvb2xlYW4+KGZhbHNlKTtcblxuICBjb25zdHJ1Y3RvcigpIHt9XG5cbiAgbmdPbkRlc3Ryb3koKSB7XG4gICAgdGhpcy5zdWJzY3JpcHRpb24udW5zdWJzY3JpYmUoKTtcbiAgfVxuXG4gIGNvbm5lY3QoKSB7XG4gICAgdGhpcy5zb2NrZXQgPSB0aGlzLmdldFNvY2tldENsaWVudCgpO1xuICAgIHRoaXMuc29ja2V0Lm9uKCdjb25uZWN0JywgKCkgPT4gdGhpcy5jb25uZWN0ZWQkLm5leHQodHJ1ZSkpO1xuICAgIHRoaXMuc29ja2V0Lm9uKCdkaXNjb25uZWN0JywgKCkgPT4gdGhpcy5jb25uZWN0ZWQkLm5leHQoZmFsc2UpKTtcbiAgfVxuXG4gIGpvaW4oc2Vzc2lvbikge1xuICAgIHRoaXMuc3Vic2NyaXB0aW9uID0gdGhpcy5jb25uZWN0ZWQkLnN1YnNjcmliZShjb25uZWN0ZWQgPT4ge1xuICAgICAgaWYgKGNvbm5lY3RlZCkge1xuICAgICAgICB0aGlzLnNvY2tldC5lbWl0KCdqb2luJywgc2Vzc2lvbik7XG4gICAgICB9XG4gICAgfSk7XG4gIH1cblxuICBsZWF2ZShzZXNzaW9uKSB7XG4gICAgdGhpcy5zb2NrZXQuZW1pdCgnbGVhdmUnLCBzZXNzaW9uKTtcbiAgICB0aGlzLnN1YnNjcmlwdGlvbi51bnN1YnNjcmliZSgpO1xuICB9XG5cbiAgZW1pdChldmVudDogc3RyaW5nLCBkYXRhOiBhbnkpIHtcbiAgICB0aGlzLnNvY2tldC5lbWl0KGV2ZW50LCBkYXRhKTtcbiAgfVxuXG4gIGxpc3RlbihldmVudDogc3RyaW5nKTogT2JzZXJ2YWJsZTxhbnk+IHtcbiAgICByZXR1cm4gbmV3IE9ic2VydmFibGUoIG9ic2VydmVyID0+IHtcbiAgICAgIHRoaXMuc29ja2V0Lm9uKGV2ZW50LCBkYXRhID0+IHtcbiAgICAgICAgb2JzZXJ2ZXIubmV4dChkYXRhKTtcbiAgICAgIH0pO1xuICAgICAgcmV0dXJuICgpID0+IHRoaXMuc29ja2V0Lm9mZihldmVudCk7XG4gICAgfSk7XG4gIH1cblxuICBnZXRTb2NrZXRDbGllbnQoKSB7XG4gICAgcmV0dXJuIHNvY2tldGlvKCcvJywge1xuICAgICAgcGF0aDogJy9pY3Avc29ja2V0LmlvJywgYWdlbnQ6IHRydWVcbiAgICB9KTtcbiAgfVxufVxuIl19
240
+ //# 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"]}
@@ -132,7 +132,7 @@ var MediaViewerComponent = /** @class */ (function () {
132
132
  if (this.enableAnnotations && !(this.multimediaContent || this.unsupportedContent)) {
133
133
  this.store.dispatch(new fromAnnoActions.LoadAnnotationSet(this.documentId));
134
134
  }
135
- if (this.enableRedactions && !(this.multimediaContent || this.unsupportedContent)) {
135
+ if (this.enableRedactions && !(this.multimediaContent || this.unsupportedContent) && this.documentId) {
136
136
  this.store.dispatch(new fromRedactActions.LoadRedactions(this.documentId));
137
137
  }
138
138
  if (this.contentType === 'image') {
@@ -425,4 +425,4 @@ if (false) {
425
425
  */
426
426
  MediaViewerComponent.prototype.cdr;
427
427
  }
428
- //# 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"]}
428
+ //# 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,13 +11,16 @@ 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
  var ImageViewerComponent = /** @class */ (function () {
15
- function ImageViewerComponent(store, printService, viewerUtilService, toolbarEvents, toolbarButtons) {
17
+ function ImageViewerComponent(store, printService, viewerUtilService, toolbarEvents, toolbarButtons, viewerEvents) {
16
18
  this.store = store;
17
19
  this.printService = printService;
18
20
  this.viewerUtilService = viewerUtilService;
19
21
  this.toolbarEvents = toolbarEvents;
20
22
  this.toolbarButtons = toolbarButtons;
23
+ this.viewerEvents = viewerEvents;
21
24
  this.mediaLoadStatus = new EventEmitter();
22
25
  this.imageViewerException = new EventEmitter();
23
26
  this.rotation = 0;
@@ -61,6 +64,26 @@ var ImageViewerComponent = /** @class */ (function () {
61
64
  */
62
65
  function (toggle) { return _this.showCommentsPanel = toggle; })));
63
66
  };
67
+ /**
68
+ * @param {?} event
69
+ * @return {?}
70
+ */
71
+ ImageViewerComponent.prototype.onImageViewerClick = /**
72
+ * @param {?} event
73
+ * @return {?}
74
+ */
75
+ function (event) {
76
+ /** @type {?} */
77
+ var 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
+ };
64
87
  /**
65
88
  * @return {?}
66
89
  */
@@ -305,7 +328,7 @@ var ImageViewerComponent = /** @class */ (function () {
305
328
  ImageViewerComponent.decorators = [
306
329
  { type: Component, args: [{
307
330
  selector: 'mv-image-viewer',
308
- 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 mvCreateTextHighlight 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"
331
+ 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"
309
332
  }] }
310
333
  ];
311
334
  /** @nocollapse */
@@ -314,7 +337,8 @@ var ImageViewerComponent = /** @class */ (function () {
314
337
  { type: PrintService },
315
338
  { type: ViewerUtilService },
316
339
  { type: ToolbarEventService },
317
- { type: ToolbarButtonVisibilityService }
340
+ { type: ToolbarButtonVisibilityService },
341
+ { type: ViewerEventService }
318
342
  ]; };
319
343
  ImageViewerComponent.propDecorators = {
320
344
  url: [{ type: Input }],
@@ -324,7 +348,8 @@ var ImageViewerComponent = /** @class */ (function () {
324
348
  height: [{ type: Input }],
325
349
  mediaLoadStatus: [{ type: Output }],
326
350
  imageViewerException: [{ type: Output }],
327
- img: [{ type: ViewChild, args: ['img',] }]
351
+ img: [{ type: ViewChild, args: ['img',] }],
352
+ onImageViewerClick: [{ type: HostListener, args: ['mousedown', ['$event'],] }]
328
353
  };
329
354
  return ImageViewerComponent;
330
355
  }());
@@ -398,5 +423,10 @@ if (false) {
398
423
  ImageViewerComponent.prototype.toolbarEvents;
399
424
  /** @type {?} */
400
425
  ImageViewerComponent.prototype.toolbarButtons;
426
+ /**
427
+ * @type {?}
428
+ * @private
429
+ */
430
+ ImageViewerComponent.prototype.viewerEvents;
401
431
  }
402
- //# 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"]}
432
+ //# 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"]}