nuxeo-development-framework 1.6.4 → 1.6.7

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 (113) hide show
  1. package/bundles/nuxeo-development-framework.umd.js +1440 -602
  2. package/bundles/nuxeo-development-framework.umd.js.map +1 -1
  3. package/esm2015/lib/Core/services/translation/translation.service.js +9 -6
  4. package/esm2015/lib/components/card/card.component.js +1 -1
  5. package/esm2015/lib/components/comments/comments.module.js +11 -5
  6. package/esm2015/lib/components/comments/components/comment-item/comment-item.component.js +61 -11
  7. package/esm2015/lib/components/comments/components/comments-dashlet/comments-dashlet.component.js +5 -2
  8. package/esm2015/lib/components/comments/components/comments-list/comments-list.component.js +7 -2
  9. package/esm2015/lib/components/comments/components/edit-delete-modal/edit-delete-modal.component.js +63 -0
  10. package/esm2015/lib/components/comments/services/comment-api.service.js +23 -1
  11. package/esm2015/lib/components/confirm-caller/confirm-caller.dialog.js +5 -3
  12. package/esm2015/lib/components/correspondence-relation/components/correspondence-relation/correspondence-relation.component.js +5 -3
  13. package/esm2015/lib/components/correspondence-relation/components/correspondence-relation-create-form/correspondence-relation-create-form.component.js +1 -1
  14. package/esm2015/lib/components/correspondence-relation/components/versions/versions.component.js +8 -4
  15. package/esm2015/lib/components/create-entity/create-entity/create-entity.component.js +11 -4
  16. package/esm2015/lib/components/cts-tags/components/correspondence-tags/correspondence-tags.component.js +47 -16
  17. package/esm2015/lib/components/cts-tags/services/tags-api.service.js +30 -1
  18. package/esm2015/lib/components/custom-toastr/components/custom-toastr/custom-toastr.component.js +2 -2
  19. package/esm2015/lib/components/documents/components/attachments-list/attachments-list.component.js +1 -1
  20. package/esm2015/lib/components/documents/components/attachments-page-provider/attachments-page-provider.component.js +1 -1
  21. package/esm2015/lib/components/documents/components/document-list/documents-list.component.js +6 -8
  22. package/esm2015/lib/components/documents/components/document-upload/document-upload.component.js +1 -1
  23. package/esm2015/lib/components/documents/components/documents/documents.component.js +4 -2
  24. package/esm2015/lib/components/documents/services/documents.service.js +4 -6
  25. package/esm2015/lib/components/dynamic-chart/dynamic-chart/dynamic-chart.component.js +43 -6
  26. package/esm2015/lib/components/dynamic-filter/dynamic-filter/dynamic-filter.component.js +30 -10
  27. package/esm2015/lib/components/dynamic-form/components/department-form/department-form.component.js +11 -5
  28. package/esm2015/lib/components/dynamic-form/components/dynamic-form/dynamic-form.component.js +14 -3
  29. package/esm2015/lib/components/dynamic-form/components/dynamic-form-department/dynamic-form-department.component.js +2 -2
  30. package/esm2015/lib/components/dynamic-form/components/dynamic-form-hijri-dateitem/dynamic-form-hijri-dateitem.component.js +8 -3
  31. package/esm2015/lib/components/dynamic-form/components/dynamic-form-select-tag/dynamic-form-select-tag.component.js +1 -1
  32. package/esm2015/lib/components/dynamic-form/components/dynamic-form-select-user-filter/dynamic-form-select-user-filter.component.js +2 -2
  33. package/esm2015/lib/components/dynamic-form/components/dynamic-form-select-users/dynamic-form-select-users.component.js +4 -3
  34. package/esm2015/lib/components/dynamic-form/components/dynamic-form-selectitem/dynamic-form-selectitem.component.js +1 -1
  35. package/esm2015/lib/components/dynamic-form/components/dynamic-form-slide-toggleitem/dynamic-form-slide-toggleitem.component.js +1 -1
  36. package/esm2015/lib/components/dynamic-form/components/dynamic-form-textarea/dynamic-form-textarea.component.js +2 -2
  37. package/esm2015/lib/components/dynamic-form/components/dynamic-form-textitem/dynamic-form-textitem.component.js +10 -7
  38. package/esm2015/lib/components/dynamic-form/components/dynamic-form-treeview-select/dropdown-treeview-select-i18n.js +15 -10
  39. package/esm2015/lib/components/dynamic-form/components/dynamic-form-treeview-select/dropdown-treeview-select.component.js +4 -2
  40. package/esm2015/lib/components/dynamic-form/components/dynamic-form-vocabulary-item/dynamic-form-vocabulary-item.component.js +6 -2
  41. package/esm2015/lib/components/dynamic-form/components/form-wrappers/date-wrapper/date-wrapper.component.js +1 -1
  42. package/esm2015/lib/components/dynamic-form/components/form-wrappers/vocabulary-wrapper/vocabulary-wrapper.component.js +1 -1
  43. package/esm2015/lib/components/dynamic-search/dynamic-search/dynamic-search.component.js +37 -6
  44. package/esm2015/lib/components/dynamic-table/dynamic-table/dynamic-table.component.js +22 -5
  45. package/esm2015/lib/components/dynamic-view/custom-document-viewer/custom-document-viewer.component.js +59 -0
  46. package/esm2015/lib/components/dynamic-view/custom-pp-viewer/custom-pp-viewer.component.js +68 -0
  47. package/esm2015/lib/components/dynamic-view/cutome-voc-viewer/cutome-voc-viewer.component.js +33 -0
  48. package/esm2015/lib/components/dynamic-view/data-viewer/data-viewer.component.js +2 -2
  49. package/esm2015/lib/components/dynamic-view/date-viewer/date-viewer.component.js +18 -12
  50. package/esm2015/lib/components/dynamic-view/department-viewer/department-viewer.component.js +44 -26
  51. package/esm2015/lib/components/dynamic-view/dynamic-view.module.js +19 -4
  52. package/esm2015/lib/components/dynamic-view/dynamic-viewe.service.js +62 -0
  53. package/esm2015/lib/components/filter/filter/filter.component.js +1 -1
  54. package/esm2015/lib/components/hijri-gregorian-datepicker/hijri-gregorian-datepicker/gregorian-datepicker/gregorian-datepicker.component.js +3 -2
  55. package/esm2015/lib/components/hijri-gregorian-datepicker/hijri-gregorian-datepicker/hijri-datepicker/hijri-datepicker.component.js +3 -2
  56. package/esm2015/lib/components/hijri-gregorian-datepicker/ngx-hijri-gregorian-datepicker.module.js +5 -1
  57. package/esm2015/lib/components/hijri-gregorian-datepicker/services/date-helper.service.js +7 -2
  58. package/esm2015/lib/components/latest-activity/components/activity-line/activity-line.component.js +2 -2
  59. package/esm2015/lib/components/latest-activity/components/latest-activity/latest-activity.component.js +1 -1
  60. package/esm2015/lib/components/latest-activity/components/single-activity/single-activity.component.js +2 -2
  61. package/esm2015/lib/components/notifications/components/notification-item/notification-item.component.js +32 -10
  62. package/esm2015/lib/components/notifications/components/notification-toast/notification-toast.component.js +1 -1
  63. package/esm2015/lib/components/notifications/components/notifications-button/notifications-button.component.js +14 -4
  64. package/esm2015/lib/components/notifications/components/notifications-list/notifications-list.component.js +8 -4
  65. package/esm2015/lib/components/pdf-tron/pdftron/pdftron.component.js +189 -32
  66. package/esm2015/lib/components/select/select/select.component.js +1 -1
  67. package/esm2015/lib/components/table/table/table.component.js +45 -15
  68. package/esm2015/lib/components/users-card/users-card.component.js +1 -1
  69. package/esm2015/lib/components/viewer-log/components/viewer-log/viewer-log.component.js +1 -1
  70. package/esm2015/lib/configuration/app-config.service.js +1 -1
  71. package/esm2015/lib/shared/components/button/button.component.js +1 -1
  72. package/esm2015/lib/shared/components/item-list/item-list.component.js +2 -2
  73. package/esm2015/lib/shared/components/user-card/user-card.component.js +1 -1
  74. package/esm2015/public-api.js +8 -1
  75. package/fesm2015/nuxeo-development-framework.js +1114 -303
  76. package/fesm2015/nuxeo-development-framework.js.map +1 -1
  77. package/lib/Core/services/translation/translation.service.d.ts +5 -2
  78. package/lib/components/comments/comments.module.d.ts +13 -12
  79. package/lib/components/comments/components/comment-item/comment-item.component.d.ts +14 -3
  80. package/lib/components/comments/components/comments-dashlet/comments-dashlet.component.d.ts +2 -1
  81. package/lib/components/comments/components/comments-list/comments-list.component.d.ts +3 -1
  82. package/lib/components/comments/components/edit-delete-modal/edit-delete-modal.component.d.ts +22 -0
  83. package/lib/components/comments/services/comment-api.service.d.ts +2 -0
  84. package/lib/components/correspondence-relation/components/versions/versions.component.d.ts +1 -0
  85. package/lib/components/cts-tags/components/correspondence-tags/correspondence-tags.component.d.ts +4 -1
  86. package/lib/components/cts-tags/services/tags-api.service.d.ts +2 -0
  87. package/lib/components/documents/services/documents.service.d.ts +1 -1
  88. package/lib/components/dynamic-chart/dynamic-chart/dynamic-chart.component.d.ts +4 -2
  89. package/lib/components/dynamic-filter/dynamic-filter/dynamic-filter.component.d.ts +11 -2
  90. package/lib/components/dynamic-form/components/dynamic-form/dynamic-form.component.d.ts +1 -0
  91. package/lib/components/dynamic-form/components/dynamic-form-hijri-dateitem/dynamic-form-hijri-dateitem.component.d.ts +4 -1
  92. package/lib/components/dynamic-form/components/dynamic-form-textitem/dynamic-form-textitem.component.d.ts +2 -1
  93. package/lib/components/dynamic-form/components/dynamic-form-treeview-select/dropdown-treeview-select-i18n.d.ts +2 -2
  94. package/lib/components/dynamic-form/components/dynamic-form-treeview-select/dropdown-treeview-select.component.d.ts +2 -1
  95. package/lib/components/dynamic-form/components/dynamic-form-vocabulary-item/dynamic-form-vocabulary-item.component.d.ts +3 -1
  96. package/lib/components/dynamic-search/dynamic-search/dynamic-search.component.d.ts +6 -3
  97. package/lib/components/dynamic-table/dynamic-table/dynamic-table.component.d.ts +6 -1
  98. package/lib/components/dynamic-view/custom-document-viewer/custom-document-viewer.component.d.ts +22 -0
  99. package/lib/components/dynamic-view/custom-pp-viewer/custom-pp-viewer.component.d.ts +28 -0
  100. package/lib/components/dynamic-view/cutome-voc-viewer/cutome-voc-viewer.component.d.ts +16 -0
  101. package/lib/components/dynamic-view/date-viewer/date-viewer.component.d.ts +8 -3
  102. package/lib/components/dynamic-view/department-viewer/department-viewer.component.d.ts +4 -3
  103. package/lib/components/dynamic-view/dynamic-view.module.d.ts +8 -5
  104. package/lib/components/dynamic-view/dynamic-viewe.service.d.ts +15 -0
  105. package/lib/components/hijri-gregorian-datepicker/ngx-hijri-gregorian-datepicker.module.d.ts +3 -2
  106. package/lib/components/hijri-gregorian-datepicker/services/date-helper.service.d.ts +1 -0
  107. package/lib/components/notifications/components/notifications-button/notifications-button.component.d.ts +5 -2
  108. package/lib/components/notifications/components/notifications-list/notifications-list.component.d.ts +3 -2
  109. package/lib/components/pdf-tron/pdftron/pdftron.component.d.ts +22 -3
  110. package/lib/components/table/table/table.component.d.ts +14 -2
  111. package/lib/configuration/app-config.service.d.ts +1 -0
  112. package/package.json +1 -1
  113. package/public-api.d.ts +7 -0
@@ -1,5 +1,5 @@
1
1
  import { __awaiter } from "tslib";
2
- import { Component, Inject, Input, ViewChild, } from '@angular/core';
2
+ import { Component, EventEmitter, Inject, Input, Output, ViewChild, } from '@angular/core';
3
3
  import WebViewer from '@pdftron/webviewer';
4
4
  import { APP_BASE_HREF } from '@angular/common';
5
5
  import { SecurePipe } from '../../../pipes/secure.pipe';
@@ -7,6 +7,7 @@ import * as i0 from "@angular/core";
7
7
  import * as i1 from "./pdftron.service";
8
8
  import * as i2 from "../../../Core/services/nuxeo/nuxeo.service";
9
9
  import * as i3 from "../../../pipes/secure.pipe";
10
+ import * as i4 from "../../../Core/services/translation/translation.service";
10
11
  /**
11
12
  * A reusable file viewer based on PDFTron Library
12
13
  * @title
@@ -21,19 +22,29 @@ import * as i3 from "../../../pipes/secure.pipe";
21
22
  * </app-pdftron>
22
23
  */
23
24
  export class PdftronComponent {
24
- constructor(cdr, pdftronService, nuxeo, baseHref, securePipe, environment) {
25
+ constructor(cdr, pdftronService, nuxeo, baseHref, securePipe, translationService, environment) {
25
26
  this.cdr = cdr;
26
27
  this.pdftronService = pdftronService;
27
28
  this.nuxeo = nuxeo;
28
29
  this.baseHref = baseHref;
29
30
  this.securePipe = securePipe;
31
+ this.translationService = translationService;
30
32
  this.environment = environment;
31
33
  this.actionClicked = false; // used to know if there is action clicked outside to start edit mode or not
32
34
  this.DOCUMENT_TYPE = 'application/pdf';
33
35
  this.fitMode = 'FitWidth';
36
+ this.events = new EventEmitter();
37
+ this.SignatureEvent = new EventEmitter(); // used to export signature to outside
38
+ this.firstTimeLoad = true; //flage to control importing signatures in the first time load only
39
+ this.firstSignatureLoad = true; // flage to pass first load of imported signatures without emitting the event
40
+ this.newSignCreation = false; // flage to indicate signature creation is created or choosed from stored ones
34
41
  }
35
42
  ngOnInit() {
36
- return __awaiter(this, void 0, void 0, function* () { });
43
+ return __awaiter(this, void 0, void 0, function* () {
44
+ this.transelationSubscrition = this.translationService.isArabic.subscribe(res => {
45
+ this.isArabic = res;
46
+ });
47
+ });
37
48
  }
38
49
  ngAfterViewInit() {
39
50
  return __awaiter(this, void 0, void 0, function* () {
@@ -56,35 +67,149 @@ export class PdftronComponent {
56
67
  forceClientSideInit: true,
57
68
  streaming: true,
58
69
  licenseKey: this.environment.pdftronLicenceKey,
59
- disabledElements: ['downloadButton'],
70
+ annotationUser: this.nuxeo.nuxeoClient.user.properties.firstName + ' ' + this.nuxeo.nuxeoClient.user.properties.lastName,
71
+ disabledElements: ['downloadButton', 'printButton'],
60
72
  }, this.viewerRef.nativeElement).then((instance) => __awaiter(this, void 0, void 0, function* () {
73
+ this.isArabic ? instance.setLanguage('ar') : instance.setLanguage('en');
61
74
  this.pdftronService.instance = this.webViewerInstance = instance;
75
+ this.addPrintButton();
62
76
  this.addDownloadButton();
77
+ this.importSignature();
78
+ this.exportingSignature();
79
+ this.deleteAnnotation();
80
+ this.exportingSavedSignature();
63
81
  this.loadDocument();
64
82
  }));
65
83
  });
66
84
  }
85
+ importSignature() {
86
+ const documentViewer = this.webViewerInstance.docViewer;
87
+ const signatureTool = documentViewer.getTool('AnnotationCreateSignature');
88
+ documentViewer.on('documentLoaded', () => {
89
+ if (this.firstTimeLoad) {
90
+ signatureTool.importSignatures([...this.userSignatures]);
91
+ this.firstTimeLoad = false;
92
+ }
93
+ });
94
+ }
95
+ exportingSavedSignature() {
96
+ const documentViewer = this.webViewerInstance.docViewer;
97
+ const SignatureCreateTool = documentViewer.getTool('AnnotationCreateSignature');
98
+ SignatureCreateTool.on('signatureSaved', (annotation) => {
99
+ if (!this.firstSignatureLoad) {
100
+ console.log('signature saved trigered');
101
+ this.newSignCreation = true;
102
+ }
103
+ this.firstSignatureLoad = false;
104
+ });
105
+ ;
106
+ }
107
+ exportingSignature() {
108
+ const documentViewer = this.webViewerInstance.docViewer;
109
+ const SignatureCreateTool = documentViewer.getTool('AnnotationCreateSignature');
110
+ SignatureCreateTool.on('annotationAdded', (annotation) => {
111
+ if (annotation && this.newSignCreation) {
112
+ this.newSignCreation = false;
113
+ this.extractAnotation(annotation, documentViewer);
114
+ console.log(annotation);
115
+ }
116
+ });
117
+ ;
118
+ }
119
+ extractAnotation(annotation, documentViewer) {
120
+ if (annotation['image']) {
121
+ // convert base64 signature into file and emit it to out side
122
+ let base64Img = annotation['image']['currentSrc'];
123
+ var arr = base64Img.split(','), mime = arr[0].match(/:(.*?);/)[1], bstr = atob(arr[1]), n = bstr.length, u8arr = new Uint8Array(n);
124
+ while (n--) {
125
+ u8arr[n] = bstr.charCodeAt(n);
126
+ }
127
+ let name = mime.replace('/', '.');
128
+ let myFile = new File([u8arr], 'mySignature.png', { type: mime });
129
+ this.SignatureEvent.emit({ data: myFile, eventName: 'export' });
130
+ }
131
+ else {
132
+ this.extractAnnotationSignature(annotation, documentViewer);
133
+ }
134
+ }
135
+ extractAnnotationSignature(annotation, docViewer) {
136
+ return __awaiter(this, void 0, void 0, function* () {
137
+ // Create a new Canvas to draw the Annotation on
138
+ const canvas = document.createElement('canvas');
139
+ // Reference the annotation from the Document
140
+ const pageMatrix = docViewer.getDocument().getPageMatrix(annotation.PageNumber);
141
+ // Set the height & width of the canvas to match the annotation
142
+ canvas.height = annotation.Height;
143
+ canvas.width = annotation.Width;
144
+ const ctx = canvas.getContext('2d');
145
+ // Translate the Annotation to the top Top Left Corner of the Canvas ie (0, 0)
146
+ ctx.translate(-annotation.X, -annotation.Y);
147
+ // Draw the Annotation onto the Canvas
148
+ annotation.draw(ctx, pageMatrix);
149
+ // Convert the Canvas to a Blob Object for Upload
150
+ canvas.toBlob((blob) => {
151
+ // Call your Blob Storage Upload Function
152
+ let name = blob.type.replace('/', '.');
153
+ let myFile = new File([blob], name);
154
+ this.SignatureEvent.emit({ data: myFile, eventName: 'export' });
155
+ });
156
+ });
157
+ }
158
+ deleteAnnotation() {
159
+ const documentViewer = this.webViewerInstance.docViewer;
160
+ const SignatureCreateTool = documentViewer.getTool('AnnotationCreateSignature');
161
+ SignatureCreateTool.on('signatureDeleted', (annotation, index) => {
162
+ console.log('there were annotations deleted');
163
+ this.userSignatures.splice(index, 1);
164
+ this.SignatureEvent.emit({ data: { signature: annotation, index: index }, eventName: 'delete' });
165
+ });
166
+ }
67
167
  addDownloadButton() {
68
168
  this.webViewerInstance.setHeaderItems((header) => {
69
169
  header.push({
70
170
  type: 'actionButton',
71
171
  img: '<svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" fill="currentColor" class="bi bi-file-earmark-arrow-down" viewBox="0 0 16 16"> <path d="M8.5 6.5a.5.5 0 0 0-1 0v3.793L6.354 9.146a.5.5 0 1 0-.708.708l2 2a.5.5 0 0 0 .708 0l2-2a.5.5 0 0 0-.708-.708L8.5 10.293V6.5z"/> <path d="M14 14V4.5L9.5 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2zM9.5 3A1.5 1.5 0 0 0 11 4.5h2V14a1 1 0 0 1-1 1H4a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1h5.5v2z"/></svg>',
72
- title: 'Download',
172
+ title: this.isArabic ? 'تنزيل' : 'Download',
173
+ onClick: () => __awaiter(this, void 0, void 0, function* () {
174
+ const { DocumentViewer, AnnotationManager, SaveOptions } = this.webViewerInstance.CoreControls;
175
+ // const xfdfString = await AnnotationManager.exportAnnotations();
176
+ const saveOptions = SaveOptions;
177
+ const options = {
178
+ filename: this.correspondance.title ? this.correspondance.title : 'myDocument.pdf',
179
+ // xfdfString,
180
+ flags: saveOptions.LINEARIZED,
181
+ downloadType: 'pdf'
182
+ };
183
+ this.pdftronService.instance.downloadPdf(options);
184
+ this.events.next('download');
185
+ // let url = this.correspondance.properties.content.data;
186
+ // let fileName = this.correspondance.properties.content.name;
187
+ // if (url && fileName) {
188
+ // let safeUrl = this.securePipe.transform(url);
189
+ // safeUrl.subscribe((url: any) => {
190
+ // const link = document.createElement('a');
191
+ // link.style.display = 'none';
192
+ // link.href = url.changingThisBreaksApplicationSecurity;
193
+ // link.download = fileName;
194
+ // document.body.appendChild(link);
195
+ // link.click();
196
+ // document.body.removeChild(link);
197
+ // this.events.next('download');
198
+ // });
199
+ // }
200
+ }),
201
+ });
202
+ });
203
+ }
204
+ addPrintButton() {
205
+ this.webViewerInstance.setHeaderItems((header) => {
206
+ header.push({
207
+ type: 'actionButton',
208
+ img: '<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><defs><style>.cls-1{fill:#abb0c4;}</style></defs><title>icon - header - print - line</title><path class="cls-1" d="M20,6H18V2H6V6H4A2,2,0,0,0,2,8v9a2,2,0,0,0,2,2H6v3H18V19h2a2,2,0,0,0,2-2V8A2,2,0,0,0,20,6ZM8,4h8V6H8Zm8,16H8V16h8Zm4-3H18V14H6v3H4V8H20Zm-4-7h2v2H16Zm-3,0h2v2H13Z"></path></svg>',
209
+ title: this.isArabic ? "طباعة" : 'Print',
73
210
  onClick: () => {
74
- let url = this.correspondance.properties.content.data;
75
- let fileName = this.correspondance.properties.content.name;
76
- if (url && fileName) {
77
- let safeUrl = this.securePipe.transform(url);
78
- safeUrl.subscribe((url) => {
79
- const link = document.createElement('a');
80
- link.style.display = 'none';
81
- link.href = url.changingThisBreaksApplicationSecurity;
82
- link.download = fileName;
83
- document.body.appendChild(link);
84
- link.click();
85
- document.body.removeChild(link);
86
- });
87
- }
211
+ this.pdftronService.instance.print();
212
+ this.events.next('print');
88
213
  },
89
214
  });
90
215
  });
@@ -118,11 +243,11 @@ export class PdftronComponent {
118
243
  }
119
244
  if (this.fileURL && this.fileURL.length) {
120
245
  this.webViewerInstance.loadDocument(this.fileURL, {
121
- filename: this.fileTitle,
246
+ xodstreaming: true,
122
247
  customHeaders: {
123
248
  Authorization: this.authHeader,
124
249
  },
125
- withCredentials: true,
250
+ // withCredentials: true,
126
251
  });
127
252
  }
128
253
  else {
@@ -170,13 +295,36 @@ export class PdftronComponent {
170
295
  this.webViewerInstance.annotManager.setReadOnly(true);
171
296
  }
172
297
  else {
173
- //edit mode opened and must be when action is clicked
174
- this.webViewerInstance.enableElements([
175
- 'toolbarGroup-Shapes',
176
- 'toolbarGroup-Edit',
177
- 'toolbarGroup-Insert',
178
- 'toolbarGroup-Annotate',
179
- ]);
298
+ // edit mode opened and must be when action is clicked
299
+ if (this.editingType) {
300
+ this.webViewerInstance.disableElements([
301
+ 'toolbarGroup-Shapes',
302
+ 'toolbarGroup-Edit',
303
+ 'toolbarGroup-Insert',
304
+ 'toolbarGroup-Annotate',
305
+ ]);
306
+ let group;
307
+ if (this.editingType === 'signDoc') {
308
+ this.webViewerInstance.enableElements([
309
+ 'toolbarGroup-Insert'
310
+ ]);
311
+ }
312
+ else if (this.editingType === 'annotate') {
313
+ this.webViewerInstance.enableElements([
314
+ 'toolbarGroup-Shapes',
315
+ 'toolbarGroup-Edit',
316
+ 'toolbarGroup-Annotate',
317
+ ]);
318
+ }
319
+ }
320
+ else {
321
+ this.webViewerInstance.enableElements([
322
+ 'toolbarGroup-Shapes',
323
+ 'toolbarGroup-Edit',
324
+ 'toolbarGroup-Insert',
325
+ 'toolbarGroup-Annotate',
326
+ ]);
327
+ }
180
328
  this.webViewerInstance.annotManager.setReadOnly(false);
181
329
  // this.webViewerInstance.setToolbarGroup('toolbarGroup-Annotate');
182
330
  }
@@ -207,10 +355,11 @@ export class PdftronComponent {
207
355
  });
208
356
  this.pdftronService.instance = this.webViewerInstance = null;
209
357
  }
358
+ this.transelationSubscrition ? this.transelationSubscrition.unsubscribe() : null;
210
359
  }
211
360
  }
212
- PdftronComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: PdftronComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.PdftronService }, { token: i2.NuxeoService }, { token: APP_BASE_HREF }, { token: i3.SecurePipe }, { token: 'environment' }], target: i0.ɵɵFactoryTarget.Component });
213
- PdftronComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.4", type: PdftronComponent, selector: "app-pdftron", inputs: { editMode: "editMode", actionClicked: "actionClicked", fileTitle: "fileTitle", docId: "docId", DOCUMENT_TYPE: "DOCUMENT_TYPE", fileData: "fileData", fitMode: "fitMode", authHeader: "authHeader", fileURL: "fileURL", correspondance: "correspondance", secrecyProperty: "secrecyProperty" }, providers: [SecurePipe], viewQueries: [{ propertyName: "viewerRef", first: true, predicate: ["fileViewer"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div #fileViewer style=\"width: 100%; height: 100%;\"></div>\r\n", styles: [""] });
361
+ PdftronComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: PdftronComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.PdftronService }, { token: i2.NuxeoService }, { token: APP_BASE_HREF }, { token: i3.SecurePipe }, { token: i4.TranslationService }, { token: 'environment' }], target: i0.ɵɵFactoryTarget.Component });
362
+ PdftronComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.4", type: PdftronComponent, selector: "app-pdftron", inputs: { editMode: "editMode", actionClicked: "actionClicked", fileTitle: "fileTitle", docId: "docId", DOCUMENT_TYPE: "DOCUMENT_TYPE", fileData: "fileData", fitMode: "fitMode", authHeader: "authHeader", fileURL: "fileURL", correspondance: "correspondance", secrecyProperty: "secrecyProperty", editingType: "editingType", userSignatures: "userSignatures" }, outputs: { events: "events", SignatureEvent: "SignatureEvent" }, providers: [SecurePipe], viewQueries: [{ propertyName: "viewerRef", first: true, predicate: ["fileViewer"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div #fileViewer style=\"width: 100%; height: 100%;\"></div>\r\n", styles: [""] });
214
363
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: PdftronComponent, decorators: [{
215
364
  type: Component,
216
365
  args: [{
@@ -222,7 +371,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImpor
222
371
  }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i1.PdftronService }, { type: i2.NuxeoService }, { type: undefined, decorators: [{
223
372
  type: Inject,
224
373
  args: [APP_BASE_HREF]
225
- }] }, { type: i3.SecurePipe }, { type: undefined, decorators: [{
374
+ }] }, { type: i3.SecurePipe }, { type: i4.TranslationService }, { type: undefined, decorators: [{
226
375
  type: Inject,
227
376
  args: ['environment']
228
377
  }] }]; }, propDecorators: { viewerRef: [{
@@ -250,5 +399,13 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImpor
250
399
  type: Input
251
400
  }], secrecyProperty: [{
252
401
  type: Input
402
+ }], editingType: [{
403
+ type: Input
404
+ }], userSignatures: [{
405
+ type: Input
406
+ }], events: [{
407
+ type: Output
408
+ }], SignatureEvent: [{
409
+ type: Output
253
410
  }] } });
254
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pdftron.component.js","sourceRoot":"","sources":["../../../../../../../projects/nuxeo-development-framework/src/lib/components/pdf-tron/pdftron/pdftron.component.ts","../../../../../../../projects/nuxeo-development-framework/src/lib/components/pdf-tron/pdftron/pdftron.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterViewInit,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ElementRef,\r\n  Inject,\r\n  Input,\r\n  OnChanges,\r\n  OnDestroy,\r\n  OnInit,\r\n  ViewChild,\r\n} from '@angular/core';\r\nimport WebViewer, { CoreControls } from '@pdftron/webviewer';\r\nimport { NuxeoService } from '../../../Core/services/nuxeo/nuxeo.service';\r\nimport { PdftronService } from './pdftron.service';\r\nimport { APP_BASE_HREF } from '@angular/common';\r\nimport { SecurePipe } from '../../../pipes/secure.pipe';\r\n\r\n/**\r\n * A reusable file viewer based on PDFTron Library\r\n * @title\r\n * PDFTron Viewer\r\n * @example\r\n * <app-pdftron\r\n *   [fileData]=\"fileData\"\r\n *   [editMode]=\"false\"\r\n *   [docId]=\"fileId\"\r\n *   [fileTitle]=\"file.title\"\r\n * >\r\n * </app-pdftron>\r\n */\r\n@Component({\r\n  selector: 'app-pdftron',\r\n  templateUrl: './pdftron.component.html',\r\n  styleUrls: ['./pdftron.component.scss'],\r\n  providers: [SecurePipe],\r\n})\r\nexport class PdftronComponent\r\n  implements OnInit, AfterViewInit, OnDestroy, OnChanges\r\n{\r\n  @ViewChild('fileViewer') viewerRef: ElementRef;\r\n  webViewerInstance;\r\n  /** Disable/Enable Annotation */\r\n  @Input()\r\n  editMode: boolean;\r\n  @Input() actionClicked = false; // used to know if there is action clicked outside to start edit mode or not\r\n  isDocumentLoading: boolean;\r\n  isFetching: boolean;\r\n  /** Document title */\r\n  @Input()\r\n  fileTitle: string;\r\n  /** Document ID */\r\n  @Input()\r\n  docId: string;\r\n  @Input()\r\n  DOCUMENT_TYPE = 'application/pdf';\r\n  @Input()\r\n  fileData;\r\n  @Input()\r\n  fitMode: 'FitWidth' | 'FitPage' | 'Zoom' = 'FitWidth';\r\n  @Input()\r\n  authHeader: string;\r\n  @Input()\r\n  fileURL: string;\r\n  @Input()\r\n  correspondance;\r\n  @Input() secrecyProperty;\r\n  constructor(\r\n    public cdr: ChangeDetectorRef,\r\n    private pdftronService: PdftronService,\r\n    private nuxeo: NuxeoService,\r\n    @Inject(APP_BASE_HREF) private baseHref: string,\r\n    private securePipe: SecurePipe,\r\n    @Inject('environment') private environment\r\n  ) {}\r\n\r\n  async ngOnInit(): Promise<void> {}\r\n\r\n  async ngAfterViewInit(): Promise<void> {\r\n    if (this.fileTitle.endsWith('.ppt')) {\r\n      this.DOCUMENT_TYPE = 'application/vnd.ms-powerpoint';\r\n    } else if (this.fileTitle.endsWith('.pptx')) {\r\n      this.DOCUMENT_TYPE =\r\n        'application/vnd.openxmlformats-officedocument.presentationml.presentation';\r\n    } else if (this.fileTitle.endsWith('.doc')) {\r\n      this.DOCUMENT_TYPE = 'application/msword';\r\n    } else if (this.fileTitle.endsWith('.docx')) {\r\n      this.DOCUMENT_TYPE =\r\n        'application/vnd.openxmlformats-officedocument.wordprocessingml.document';\r\n    }\r\n    WebViewer(\r\n      {\r\n        path: this.baseHref + '/assets/pdftrons',\r\n        forceClientSideInit: true,\r\n        streaming: true,\r\n        licenseKey: this.environment.pdftronLicenceKey,\r\n        disabledElements: ['downloadButton'],\r\n\r\n      },\r\n      this.viewerRef.nativeElement\r\n    ).then(async (instance) => {\r\n      this.pdftronService.instance = this.webViewerInstance = instance;\r\n      this.addDownloadButton();\r\n      this.loadDocument();\r\n    });\r\n  }\r\n  \r\n  addDownloadButton() {\r\n    this.webViewerInstance.setHeaderItems((header) => {\r\n      header.push({\r\n        type: 'actionButton',\r\n        img: '<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" fill=\"currentColor\" class=\"bi bi-file-earmark-arrow-down\" viewBox=\"0 0 16 16\"> <path d=\"M8.5 6.5a.5.5 0 0 0-1 0v3.793L6.354 9.146a.5.5 0 1 0-.708.708l2 2a.5.5 0 0 0 .708 0l2-2a.5.5 0 0 0-.708-.708L8.5 10.293V6.5z\"/> <path d=\"M14 14V4.5L9.5 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2zM9.5 3A1.5 1.5 0 0 0 11 4.5h2V14a1 1 0 0 1-1 1H4a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1h5.5v2z\"/></svg>',\r\n        title: 'Download',\r\n        onClick: () => {\r\n          let url = this.correspondance.properties.content.data;\r\n          let fileName = this.correspondance.properties.content.name;\r\n          if (url && fileName) {\r\n            let safeUrl = this.securePipe.transform(url);\r\n            safeUrl.subscribe((url: any) => {\r\n              const link = document.createElement('a');\r\n              link.style.display = 'none';\r\n              link.href = url.changingThisBreaksApplicationSecurity;\r\n              link.download = fileName;\r\n              document.body.appendChild(link);\r\n              link.click();\r\n              document.body.removeChild(link);\r\n            });\r\n          }\r\n        },\r\n      });\r\n    });\r\n  }\r\n  addWatermark() {\r\n    const userinfo = this.nuxeo.nuxeoClient.user.properties;\r\n    this.pdftronService.addWatermark(\r\n      `${userinfo.username}    `\r\n      // `${userinfo.firstName} ${\r\n      //   userinfo.lastName\r\n      // } `\r\n    );\r\n  }\r\n  loadDocument(): void {\r\n    if (!this.webViewerInstance || (!this.fileData && !this.fileURL)) {\r\n      return;\r\n    }\r\n    const { docViewer, annotManager, Annotations } = this.webViewerInstance;\r\n    docViewer.on('documentLoaded', () => {\r\n      let fitMode = this.webViewerInstance.FitMode.FitWidth;\r\n      if (this.fitMode === 'FitPage') {\r\n        fitMode = this.webViewerInstance.FitMode.FitPage;\r\n      } else if (this.fitMode === 'Zoom') {\r\n        fitMode = this.webViewerInstance.FitMode.Zoom;\r\n      }\r\n      this.webViewerInstance.setFitMode(fitMode);\r\n    });\r\n    if (!this.editMode) {\r\n      this.webViewerInstance.annotManager.setReadOnly(true);\r\n      // instance.enableTools([]);\r\n    }\r\n    if (this.fileURL && this.fileURL.length) {\r\n      this.webViewerInstance.loadDocument(this.fileURL, {\r\n        filename: this.fileTitle,\r\n        customHeaders: {\r\n          Authorization: this.authHeader,\r\n        },\r\n        withCredentials: true,\r\n      });\r\n    } else {\r\n      this.webViewerInstance.loadDocument(\r\n        new Blob([new Uint8Array(this.fileData)], { type: this.DOCUMENT_TYPE }),\r\n        {\r\n          filename: this.fileTitle,\r\n        }\r\n      );\r\n    }\r\n\r\n    this.isFetching = false;\r\n    if (this.correspondance !== undefined) {\r\n      // if we need to check on secrecy level for adding water mark or not \r\n      if (this.environment.enableViewerWaterMark && this.secrecyProperty) {\r\n        // check for secrecy level befor adding watermark\r\n        if (this.correspondance.properties[this.secrecyProperty] && this.correspondance.properties[this.secrecyProperty] !== 'Normal') {\r\n          this.addWatermark()\r\n        }\r\n      }\r\n      else if (this.environment.enableViewerWaterMark && !this.secrecyProperty) {\r\n        this.addWatermark();\r\n      }\r\n    }\r\n    this.cdr.detectChanges();\r\n  }\r\n  async exportAsBlob(): Promise<Blob> {\r\n    const doc = this.webViewerInstance.docViewer.getDocument();\r\n    const xfdfString =\r\n      await this.webViewerInstance.annotManager.exportAnnotations();\r\n    const data = await doc.getFileData({\r\n      // saves the document with annotations in it\r\n      xfdfString,\r\n    });\r\n    const arr = new Uint8Array(data);\r\n    const blob = new Blob([arr], { type: this.DOCUMENT_TYPE });\r\n    return Promise.resolve(blob);\r\n  }\r\n\r\n  toggleEdit(): void {\r\n    if (!this.actionClicked) {\r\n      // action clicked is not clicked then no update mode opened\r\n      this.webViewerInstance.disableElements([\r\n        'toolbarGroup-Shapes',\r\n        'toolbarGroup-Edit',\r\n        'toolbarGroup-Insert',\r\n        'toolbarGroup-Annotate',\r\n      ]);\r\n      this.webViewerInstance.annotManager.setReadOnly(true);\r\n    } else {\r\n      //edit mode opened and must be when action is clicked\r\n      this.webViewerInstance.enableElements([\r\n        'toolbarGroup-Shapes',\r\n        'toolbarGroup-Edit',\r\n        'toolbarGroup-Insert',\r\n        'toolbarGroup-Annotate',\r\n      ]);\r\n      this.webViewerInstance.annotManager.setReadOnly(false);\r\n      // this.webViewerInstance.setToolbarGroup('toolbarGroup-Annotate');\r\n    }\r\n  }\r\n  ngOnChanges(changes): void {\r\n    if (this.webViewerInstance) {\r\n      this.toggleEdit();\r\n      if (\r\n        changes.urlFileContent &&\r\n        changes.urlFileContent.previousValue &&\r\n        changes.urlFileContent.previousValue !==\r\n          changes.urlFileContent.currentValue\r\n      ) {\r\n        this.ngOnDestroy();\r\n        this.ngOnInit();\r\n        this.ngAfterViewInit();\r\n      }\r\n    }\r\n  }\r\n  private pdfTronEvent(event) {\r\n    if (this[event.action]) {\r\n      // method exists in the component\r\n      //  this[event.action](event.params); // call it\r\n    }\r\n  }\r\n  ngOnDestroy(): void {\r\n    if (this.webViewerInstance) {\r\n      this.webViewerInstance.closeDocument().then(() => {\r\n        console.log('document closed!');\r\n      });\r\n      this.pdftronService.instance = this.webViewerInstance = null;\r\n    }\r\n  }\r\n}\r\n","<div #fileViewer style=\"width: 100%; height: 100%;\"></div>\r\n"]}
411
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pdftron.component.js","sourceRoot":"","sources":["../../../../../../../projects/nuxeo-development-framework/src/lib/components/pdf-tron/pdftron/pdftron.component.ts","../../../../../../../projects/nuxeo-development-framework/src/lib/components/pdf-tron/pdftron/pdftron.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterViewInit,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  Inject,\r\n  Input,\r\n  OnChanges,\r\n  OnDestroy,\r\n  OnInit,\r\n  Output,\r\n  ViewChild,\r\n} from '@angular/core';\r\nimport WebViewer, { CoreControls } from '@pdftron/webviewer';\r\nimport { NuxeoService } from '../../../Core/services/nuxeo/nuxeo.service';\r\nimport { PdftronService } from './pdftron.service';\r\nimport { APP_BASE_HREF } from '@angular/common';\r\nimport { SecurePipe } from '../../../pipes/secure.pipe';\r\nimport { ThrowStmt } from '@angular/compiler';\r\nimport { TranslationService } from '../../../Core/services/translation/translation.service';\r\nimport { Subscription } from 'rxjs';\r\n\r\n/**\r\n * A reusable file viewer based on PDFTron Library\r\n * @title\r\n * PDFTron Viewer\r\n * @example\r\n * <app-pdftron\r\n *   [fileData]=\"fileData\"\r\n *   [editMode]=\"false\"\r\n *   [docId]=\"fileId\"\r\n *   [fileTitle]=\"file.title\"\r\n * >\r\n * </app-pdftron>\r\n */\r\n@Component({\r\n  selector: 'app-pdftron',\r\n  templateUrl: './pdftron.component.html',\r\n  styleUrls: ['./pdftron.component.scss'],\r\n  providers: [SecurePipe],\r\n})\r\nexport class PdftronComponent\r\n  implements OnInit, AfterViewInit, OnDestroy, OnChanges {\r\n  @ViewChild('fileViewer') viewerRef: ElementRef;\r\n  webViewerInstance;\r\n  /** Disable/Enable Annotation */\r\n  @Input()\r\n  editMode: boolean;\r\n  @Input() actionClicked = false; // used to know if there is action clicked outside to start edit mode or not\r\n  isDocumentLoading: boolean;\r\n  isFetching: boolean;\r\n  /** Document title */\r\n  @Input()\r\n  fileTitle: string;\r\n  /** Document ID */\r\n  @Input()\r\n  docId: string;\r\n  @Input()\r\n  DOCUMENT_TYPE = 'application/pdf';\r\n  @Input()\r\n  fileData;\r\n  @Input()\r\n  fitMode: 'FitWidth' | 'FitPage' | 'Zoom' = 'FitWidth';\r\n  @Input()\r\n  authHeader: string;\r\n  @Input()\r\n  fileURL: string;\r\n  @Input()\r\n  correspondance;\r\n\r\n  @Input() secrecyProperty; // used to add watermark acording certain secrecy level\r\n  @Input() editingType;\r\n  @Input() userSignatures;\r\n  @Output()\r\n  events = new EventEmitter();\r\n  @Output() SignatureEvent = new EventEmitter(); // used to export signature to outside\r\n  firstTimeLoad = true; //flage to control importing signatures in the first time load only\r\n  firstSignatureLoad = true; // flage to pass first load of imported signatures without emitting the event \r\n  newSignCreation = false; // flage to indicate signature creation is created or choosed from stored ones\r\n  transelationSubscrition : Subscription;\r\n  isArabic;\r\n  constructor(\r\n    public cdr: ChangeDetectorRef,\r\n    private pdftronService: PdftronService,\r\n    private nuxeo: NuxeoService,\r\n    @Inject(APP_BASE_HREF) private baseHref: string,\r\n    private securePipe: SecurePipe,\r\n    private translationService : TranslationService,\r\n    @Inject('environment') private environment\r\n  ) { }\r\n\r\n  async ngOnInit(): Promise<void> {\r\n    this.transelationSubscrition = this.translationService.isArabic.subscribe(res => {\r\n      this.isArabic = res ;\r\n    })\r\n   }\r\n\r\n  async ngAfterViewInit(): Promise<void> {\r\n    if (this.fileTitle.endsWith('.ppt')) {\r\n      this.DOCUMENT_TYPE = 'application/vnd.ms-powerpoint';\r\n    } else if (this.fileTitle.endsWith('.pptx')) {\r\n      this.DOCUMENT_TYPE =\r\n        'application/vnd.openxmlformats-officedocument.presentationml.presentation';\r\n    } else if (this.fileTitle.endsWith('.doc')) {\r\n      this.DOCUMENT_TYPE = 'application/msword';\r\n    } else if (this.fileTitle.endsWith('.docx')) {\r\n      this.DOCUMENT_TYPE =\r\n        'application/vnd.openxmlformats-officedocument.wordprocessingml.document';\r\n    }\r\n    WebViewer(\r\n      {\r\n        path: this.baseHref + '/assets/pdftrons',\r\n        forceClientSideInit: true,\r\n        streaming: true,\r\n        licenseKey: this.environment.pdftronLicenceKey,\r\n        annotationUser: this.nuxeo.nuxeoClient.user.properties.firstName + ' ' + this.nuxeo.nuxeoClient.user.properties.lastName,\r\n        disabledElements: ['downloadButton', 'printButton'],\r\n\r\n      },\r\n      this.viewerRef.nativeElement\r\n    ).then(async (instance) => {\r\n      this.isArabic ? instance.setLanguage('ar') : instance.setLanguage('en') ;\r\n      this.pdftronService.instance = this.webViewerInstance = instance;\r\n      \r\n      this.addPrintButton();\r\n      this.addDownloadButton();\r\n      this.importSignature();\r\n      this.exportingSignature();\r\n      this.deleteAnnotation();\r\n      this.exportingSavedSignature();\r\n      this.loadDocument();\r\n\r\n    });\r\n  }\r\n\r\n  importSignature() {\r\n    const documentViewer = this.webViewerInstance.docViewer;\r\n    const signatureTool = documentViewer.getTool('AnnotationCreateSignature');\r\n\r\n    documentViewer.on('documentLoaded', () => {\r\n      if(this.firstTimeLoad){\r\n        signatureTool.importSignatures([...this.userSignatures]);\r\n        this.firstTimeLoad = false;\r\n      }\r\n    })\r\n  }\r\n  \r\n  exportingSavedSignature() {\r\n    const documentViewer = this.webViewerInstance.docViewer;\r\n    const SignatureCreateTool = documentViewer.getTool('AnnotationCreateSignature')\r\n    SignatureCreateTool.on('signatureSaved', (annotation) => {\r\n      if(!this.firstSignatureLoad){\r\n        console.log('signature saved trigered');\r\n        this.newSignCreation = true;\r\n      }\r\n      this.firstSignatureLoad = false;\r\n    });;\r\n  }\r\n  \r\n  exportingSignature() {\r\n    const documentViewer = this.webViewerInstance.docViewer;\r\n    const SignatureCreateTool = documentViewer.getTool('AnnotationCreateSignature')\r\n    SignatureCreateTool.on('annotationAdded', (annotation) => {\r\n      if (annotation && this.newSignCreation) {\r\n        this.newSignCreation = false;\r\n        this.extractAnotation(annotation , documentViewer);\r\n        console.log(annotation)\r\n      }\r\n    });;\r\n  }\r\n\r\n  extractAnotation(annotation , documentViewer){\r\n    if(annotation['image']){\r\n      // convert base64 signature into file and emit it to out side \r\n      let base64Img = annotation['image']['currentSrc'];\r\n      var arr = base64Img.split(','),\r\n      mime = arr[0].match(/:(.*?);/)[1],\r\n      bstr = atob(arr[1]), \r\n      n = bstr.length, \r\n      u8arr = new Uint8Array(n);\r\n      while(n--){\r\n          u8arr[n] = bstr.charCodeAt(n);\r\n      }\r\n      let name = mime.replace('/' , '.')\r\n      let myFile = new File([u8arr], 'mySignature.png', {type:mime});\r\n      this.SignatureEvent.emit({ data: myFile, eventName: 'export' });\r\n\r\n    }else{\r\n      this.extractAnnotationSignature(annotation , documentViewer)\r\n    }\r\n  }\r\n\r\n  async extractAnnotationSignature(annotation, docViewer) {\r\n    // Create a new Canvas to draw the Annotation on\r\n    const canvas = document.createElement('canvas');\r\n    // Reference the annotation from the Document\r\n    const pageMatrix = docViewer.getDocument().getPageMatrix(annotation.PageNumber);\r\n    // Set the height & width of the canvas to match the annotation\r\n    canvas.height = annotation.Height;\r\n    canvas.width = annotation.Width;\r\n    const ctx = canvas.getContext('2d');\r\n    // Translate the Annotation to the top Top Left Corner of the Canvas ie (0, 0)\r\n    ctx.translate(-annotation.X, -annotation.Y);\r\n    // Draw the Annotation onto the Canvas\r\n    annotation.draw(ctx, pageMatrix);\r\n    // Convert the Canvas to a Blob Object for Upload\r\n    canvas.toBlob((blob) => {\r\n      // Call your Blob Storage Upload Function\r\n      let name = blob.type.replace('/' , '.')\r\n      let myFile = new File([blob], name);\r\n      this.SignatureEvent.emit({ data: myFile, eventName: 'export' });\r\n    });\r\n  }\r\n\r\n  deleteAnnotation() {\r\n    const documentViewer = this.webViewerInstance.docViewer;\r\n    const SignatureCreateTool = documentViewer.getTool('AnnotationCreateSignature');\r\n    SignatureCreateTool.on('signatureDeleted', (annotation, index) => {\r\n      console.log('there were annotations deleted');\r\n      this.userSignatures.splice(index , 1);\r\n      this.SignatureEvent.emit({ data: { signature: annotation, index: index }, eventName: 'delete' });\r\n    });\r\n  }\r\n\r\n\r\n\r\n  addDownloadButton() {\r\n    this.webViewerInstance.setHeaderItems((header) => {\r\n      header.push({\r\n        type: 'actionButton',\r\n        img: '<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" fill=\"currentColor\" class=\"bi bi-file-earmark-arrow-down\" viewBox=\"0 0 16 16\"> <path d=\"M8.5 6.5a.5.5 0 0 0-1 0v3.793L6.354 9.146a.5.5 0 1 0-.708.708l2 2a.5.5 0 0 0 .708 0l2-2a.5.5 0 0 0-.708-.708L8.5 10.293V6.5z\"/> <path d=\"M14 14V4.5L9.5 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2zM9.5 3A1.5 1.5 0 0 0 11 4.5h2V14a1 1 0 0 1-1 1H4a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1h5.5v2z\"/></svg>',\r\n        title: this.isArabic ? 'تنزيل' : 'Download',\r\n        onClick: async () => {\r\n          const { DocumentViewer, AnnotationManager, SaveOptions } = this.webViewerInstance.CoreControls;\r\n          // const xfdfString = await AnnotationManager.exportAnnotations();\r\n          const saveOptions = SaveOptions;\r\n          const options = {\r\n            filename: this.correspondance.title ? this.correspondance.title : 'myDocument.pdf',\r\n            // xfdfString,\r\n            flags: saveOptions.LINEARIZED,\r\n            downloadType: 'pdf'\r\n          };\r\n\r\n          this.pdftronService.instance.downloadPdf(options);\r\n          this.events.next('download');\r\n          // let url = this.correspondance.properties.content.data;\r\n          // let fileName = this.correspondance.properties.content.name;\r\n          // if (url && fileName) {\r\n          //   let safeUrl = this.securePipe.transform(url);\r\n          //   safeUrl.subscribe((url: any) => {\r\n          //     const link = document.createElement('a');\r\n          //     link.style.display = 'none';\r\n          //     link.href = url.changingThisBreaksApplicationSecurity;\r\n          //     link.download = fileName;\r\n          //     document.body.appendChild(link);\r\n          //     link.click();\r\n          //     document.body.removeChild(link);\r\n          //     this.events.next('download');\r\n          //   });\r\n          // }\r\n        },\r\n      });\r\n    });\r\n  }\r\n\r\n  addPrintButton() {\r\n    this.webViewerInstance.setHeaderItems((header) => {\r\n      header.push({\r\n        type: 'actionButton',\r\n        img: '<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\"><defs><style>.cls-1{fill:#abb0c4;}</style></defs><title>icon - header - print - line</title><path class=\"cls-1\" d=\"M20,6H18V2H6V6H4A2,2,0,0,0,2,8v9a2,2,0,0,0,2,2H6v3H18V19h2a2,2,0,0,0,2-2V8A2,2,0,0,0,20,6ZM8,4h8V6H8Zm8,16H8V16h8Zm4-3H18V14H6v3H4V8H20Zm-4-7h2v2H16Zm-3,0h2v2H13Z\"></path></svg>',\r\n        title: this.isArabic ? \"طباعة\" : 'Print',\r\n        onClick: () => {\r\n          this.pdftronService.instance.print();\r\n          this.events.next('print');\r\n        },\r\n      });\r\n    });\r\n  }\r\n\r\n  addWatermark() {\r\n    const userinfo = this.nuxeo.nuxeoClient.user.properties;\r\n    this.pdftronService.addWatermark(\r\n      `${userinfo.username}    `\r\n      // `${userinfo.firstName} ${\r\n      //   userinfo.lastName\r\n      // } `\r\n    );\r\n  }\r\n\r\n  loadDocument(): void {\r\n    if (!this.webViewerInstance || (!this.fileData && !this.fileURL)) {\r\n      return;\r\n    }\r\n    const { docViewer, annotManager, Annotations } = this.webViewerInstance;\r\n    docViewer.on('documentLoaded', () => {\r\n      let fitMode = this.webViewerInstance.FitMode.FitWidth;\r\n      if (this.fitMode === 'FitPage') {\r\n        fitMode = this.webViewerInstance.FitMode.FitPage;\r\n      } else if (this.fitMode === 'Zoom') {\r\n        fitMode = this.webViewerInstance.FitMode.Zoom;\r\n      }\r\n      this.webViewerInstance.setFitMode(fitMode);\r\n    });\r\n    if (!this.editMode) {\r\n      this.webViewerInstance.annotManager.setReadOnly(true);\r\n      // instance.enableTools([]);\r\n    }\r\n    if (this.fileURL && this.fileURL.length) {\r\n      this.webViewerInstance.loadDocument(this.fileURL, {\r\n        xodstreaming:true,\r\n        customHeaders: {\r\n          Authorization: this.authHeader,\r\n        },\r\n        // withCredentials: true,\r\n      });\r\n    } else {\r\n      this.webViewerInstance.loadDocument(\r\n        new Blob([new Uint8Array(this.fileData)], { type: this.DOCUMENT_TYPE }),\r\n        {\r\n          filename: this.fileTitle,\r\n        }\r\n      );\r\n    }\r\n\r\n    this.isFetching = false;\r\n    if (this.correspondance !== undefined) {\r\n      // if we need to check on secrecy level for adding water mark or not \r\n      if (this.environment.enableViewerWaterMark && this.secrecyProperty) {\r\n        // check for secrecy level befor adding watermark\r\n        if (this.correspondance.properties[this.secrecyProperty] && this.correspondance.properties[this.secrecyProperty] !== 'Normal') {\r\n          this.addWatermark()\r\n        }\r\n      }\r\n      else if (this.environment.enableViewerWaterMark && !this.secrecyProperty) {\r\n        this.addWatermark();\r\n      }\r\n    }\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  async exportAsBlob(): Promise<Blob> {\r\n    const doc = this.webViewerInstance.docViewer.getDocument();\r\n    const xfdfString =\r\n      await this.webViewerInstance.annotManager.exportAnnotations();\r\n    const data = await doc.getFileData({\r\n      // saves the document with annotations in it\r\n      xfdfString,\r\n    });\r\n    const arr = new Uint8Array(data);\r\n    const blob = new Blob([arr], { type: this.DOCUMENT_TYPE });\r\n    return Promise.resolve(blob);\r\n  }\r\n\r\n  toggleEdit(): void {\r\n    if (!this.actionClicked) {\r\n      // action clicked is not clicked then no update mode opened\r\n      this.webViewerInstance.disableElements([\r\n        'toolbarGroup-Shapes',\r\n        'toolbarGroup-Edit',\r\n        'toolbarGroup-Insert',\r\n        'toolbarGroup-Annotate',\r\n      ]);\r\n      this.webViewerInstance.annotManager.setReadOnly(true);\r\n    } else {\r\n      // edit mode opened and must be when action is clicked\r\n      if (this.editingType) {\r\n        this.webViewerInstance.disableElements([\r\n          'toolbarGroup-Shapes',\r\n          'toolbarGroup-Edit',\r\n          'toolbarGroup-Insert',\r\n          'toolbarGroup-Annotate',\r\n        ]);\r\n        let group ;\r\n        if(this.editingType === 'signDoc'){\r\n          this.webViewerInstance.enableElements([\r\n            'toolbarGroup-Insert'\r\n          ]);\r\n\r\n        }else if(this.editingType === 'annotate'){\r\n          this.webViewerInstance.enableElements([\r\n            'toolbarGroup-Shapes',\r\n            'toolbarGroup-Edit',\r\n            'toolbarGroup-Annotate',\r\n          ]);\r\n        }\r\n      } else {\r\n        this.webViewerInstance.enableElements([\r\n          'toolbarGroup-Shapes',\r\n          'toolbarGroup-Edit',\r\n          'toolbarGroup-Insert',\r\n          'toolbarGroup-Annotate',\r\n        ]);\r\n      }\r\n      this.webViewerInstance.annotManager.setReadOnly(false);\r\n      // this.webViewerInstance.setToolbarGroup('toolbarGroup-Annotate');\r\n    }\r\n  }\r\n\r\n  ngOnChanges(changes): void {\r\n    if (this.webViewerInstance) {\r\n      this.toggleEdit();\r\n      if (\r\n        changes.urlFileContent &&\r\n        changes.urlFileContent.previousValue &&\r\n        changes.urlFileContent.previousValue !==\r\n        changes.urlFileContent.currentValue\r\n      ) {\r\n        this.ngOnDestroy();\r\n        this.ngOnInit();\r\n        this.ngAfterViewInit();\r\n      }\r\n    }\r\n  }\r\n\r\n  private pdfTronEvent(event) {\r\n    if (this[event.action]) {\r\n      // method exists in the component\r\n      //  this[event.action](event.params); // call it\r\n    }\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    if (this.webViewerInstance) {\r\n      this.webViewerInstance.closeDocument().then(() => {\r\n        console.log('document closed!');\r\n      });\r\n      this.pdftronService.instance = this.webViewerInstance = null;\r\n    }\r\n    this.transelationSubscrition ? this.transelationSubscrition.unsubscribe() : null;\r\n  }\r\n}\r\n","<div #fileViewer style=\"width: 100%; height: 100%;\"></div>\r\n"]}
@@ -78,7 +78,7 @@ SelectComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", versio
78
78
  useExisting: forwardRef(() => SelectComponent),
79
79
  multi: true,
80
80
  },
81
- ], usesOnChanges: true, ngImport: i0, template: "<ng-container *ngIf=\"label\">\r\n <div>\r\n <label class=\"select-label\"\r\n >{{ label | translate\r\n }}<span *ngIf=\"false\" class=\"text-danger m-1\">*</span></label\r\n >\r\n </div>\r\n</ng-container>\r\n<ng-select\r\n [items]=\"buffer\"\r\n [bindLabel]=\"bindLabel\"\r\n [bindValue]=\"bindValue\"\r\n [placeholder]=\"placeholder\"\r\n [multiple]=\"multiple\"\r\n [searchable]=\"searchable\"\r\n [closeOnSelect]=\"closeOnSelect\"\r\n [hideSelected]=\"hideSelectedItems\"\r\n [loading]=\"loading\"\r\n (scrollToEnd)=\"onScrollToEnd()\"\r\n (change)=\"emitSelection($event)\"\r\n [disabled]=\"disabled\"\r\n [(ngModel)]=\"selection\"\r\n>\r\n <!-- template for viewing options in single and multi select -->\r\n <ng-template\r\n ng-option-tmp\r\n let-item=\"item\"\r\n let-item$=\"item$\"\r\n let-index=\"index\"\r\n >\r\n <div class=\"option-wrapper\">\r\n <span class=\"check-box-wrapper\" *ngIf=\"multiple\">\r\n <input\r\n id=\"item-{{ index }}\"\r\n type=\"checkbox\"\r\n [ngModel]=\"item$.selected\"\r\n />\r\n <span class=\"icon-wrapper\">\r\n <span class=\"bi bi-check2 icon\"></span>\r\n </span>\r\n </span>\r\n <span class=\"label-wrapper\">\r\n {{ item[bindLabel] | translate }}\r\n </span>\r\n </div>\r\n </ng-template>\r\n\r\n <!-- template for viewing single select selected value -->\r\n <ng-template ng-label-tmp let-item=\"item\">\r\n {{ (bindLabel ? item[bindLabel] : item) | translate }}\r\n </ng-template>\r\n\r\n <!-- template for viewing multi select selected values -->\r\n <ng-template ng-multi-label-tmp let-items=\"items\" let-clear=\"clear\">\r\n <div class=\"ng-value\" *ngFor=\"let item of items ? items : []\">\r\n <span class=\"ng-value-label\">\r\n {{ (bindLabel ? item[bindLabel] : item) | translate }}\r\n </span>\r\n <span class=\"ng-value-icon right\" (click)=\"clear(item)\" aria-hidden=\"true\"\r\n >\u00D7</span\r\n >\r\n </div>\r\n </ng-template>\r\n</ng-select>\r\n", styles: [".bi{margin:0!important}.memo-sorting-wrapper{width:265px;margin:0 10px;height:100%;display:flex}.memo-sorting-wrapper .sorting-direction{width:65px;height:40px;background-color:#465573;color:#fff;font-size:20px;display:flex;justify-content:center;align-items:center;cursor:pointer}.memo-sorting-wrapper .memo-sorting-trigger{width:calc(100% - 65px);height:100%;background-color:transparent;border:1px solid lightgrey;display:flex;justify-content:space-between;align-items:center;padding:0 15px;font-size:14px}.memo-sorting-wrapper .memo-sorting-trigger i{font-size:16px;color:gray}.memo-sorting-menu{width:200px}.my-button{border:1px solid #465573;color:#465573;border-radius:5px;background-color:transparent;font-weight:bold;min-width:80px;height:40px}.my-button.reset{border:none}.my-button:hover{color:#fff;background-color:#465573}.my-button:hover.reset{color:#465573;border:1px solid #465573;background-color:#fff}.app-property-value .app-input-wrapper label{color:#646f85;font-size:13px;margin-bottom:5px}.app-property-value .app-input-wrapper label .text-danger{font-size:16px;line-height:14px;margin:0 5px!important}.app-property-value .app-input-wrapper .form-control{border:1px solid #ccc;border-radius:5px;background-color:#8f98aa1a;height:40px}.app-property-value .app-input-wrapper .form-control:disabled{background-color:#e9ecef!important}.app-property-value .app-input-wrapper .form-control:focus{border:1px solid #1a96c6;box-shadow:0 0 4px #79c3c26b!important}.app-property-value .app-input-wrapper .app-textitem-editable-error .error-containers{list-style:none;padding:0;margin:0;font-size:14px}.app-property-value .app-input-wrapper .app-textitem-editable-error .error-containers .error{margin-top:5px}.autocomplete-container .input-container input:focus,hijri-gregorian-datepicker .form-group .input-group .form-control:focus,.ng-select.ng-select-focused .ng-select-container{border:1px solid #1a96c6!important;box-shadow:0 0 4px #79c3c26b!important}input::placeholder{font-size:12px}.form-control:focus{box-shadow:none!important}.mat-stepper-horizontal{margin-top:-25px}.mat-stepper-horizontal .mat-horizontal-stepper-header-container .mat-step-header.cdk-program-focused{background-color:transparent}.mat-stepper-horizontal .mat-horizontal-stepper-header-container .mat-step-header .mat-step-icon-selected{background-color:transparent;color:#fff;background-image:linear-gradient(to right,#0dbab5,#1a96c6)}@media only screen and (max-width: 576px){.mat-stepper-horizontal .mat-horizontal-stepper-header-container .mat-step-header .mat-step-label .mat-step-text-label{white-space:pre-wrap;overflow:visible}}.mat-stepper-horizontal .mat-horizontal-content-container{overflow:visible}@media only screen and (max-width: 768px){.mat-stepper-horizontal .mat-horizontal-content-container{padding:0 0 24px}}.mat-stepper-horizontal.rtl .mat-horizontal-stepper-header:first-child:after,.mat-stepper-horizontal.rtl .mat-horizontal-stepper-header:last-child:before{display:none}.mat-stepper-horizontal.rtl .mat-horizontal-stepper-header:first-child:before{border-top-width:1px;border-top-style:solid;content:\"\";display:inline-block;height:0;position:absolute;width:calc(50% - 20px);left:0}.mat-stepper-horizontal.rtl .mat-horizontal-stepper-header:last-child:after{border-top-width:1px;border-top-style:solid;content:\"\";display:inline-block;height:0;position:absolute;width:calc(50% - 20px);right:0}.form-wrapper{padding:30px 15px;border:1px solid #dde0e2}.form-wrapper .buttons-wrapper{display:flex;justify-content:space-between}.form-wrapper .buttons-wrapper .action-buttons-wrapper{display:flex}.form-wrapper .buttons-wrapper button{background-image:linear-gradient(to right,#0dbab5,#1a96c6);height:40px;color:#fff;border:none;width:125px;margin-top:20px;border-radius:5px}.form-wrapper .buttons-wrapper button:disabled{opacity:.4;cursor:not-allowed}.form-wrapper .buttons-wrapper button:hover{opacity:.7}.form-wrapper .upload-wrapper{display:flex;flex-direction:column;justify-content:flex-end}.form-wrapper .upload-wrapper label{color:#8f98aa;font-size:14px}.form-wrapper .upload-wrapper button{padding:10px;border:1px solid lightgray}.form-wrapper .upload-wrapper button span{margin:0 10px}.my-dynamic-viewer{display:flex;align-items:center;font-size:12px;min-height:30px}.my-dynamic-viewer .my-label{font-size:12px;font-weight:500;width:150px;word-break:break-word}@media (max-width: 992px){.my-dynamic-viewer .my-label{width:50%}}.my-dynamic-viewer .my-value{width:calc(100% - 150px);word-break:break-word}@media (max-width: 992px){.my-dynamic-viewer .my-value{width:50%}}.my-dynamic-viewer .direction-img{font-size:14px}.my-dynamic-viewer .direction-img .incoming{display:none}.my-dynamic-viewer .direction-img .outgoing{display:none}.my-dynamic-viewer.draft .my-value{color:#596973}.my-dynamic-viewer.inProgress .my-value{color:#3c3cf0}.my-dynamic-viewer.registered .my-value{color:#4f008c}.my-dynamic-viewer.archived .my-value{color:#fbb62c}.my-dynamic-viewer.closed .my-value{color:#00dca5}.my-dynamic-viewer.approved .my-value{color:#06a57e}.my-dynamic-viewer.assigned .my-value{color:#fd6670}.my-dynamic-viewer.sent .my-value{color:#3c3cf0}.my-dynamic-viewer.published .my-value{color:#00dca5}.my-dynamic-viewer.Outgoing .my-value{display:flex}.my-dynamic-viewer.Outgoing .my-value .direction-img .outgoing{color:#fbb62c;margin:1px 5px;display:flex}.my-dynamic-viewer.Outgoing .my-value .text{margin:0 5px}.my-dynamic-viewer.Incoming .my-value{display:flex}.my-dynamic-viewer.Incoming .my-value .direction-img .incoming{color:#00dca5;display:flex}.my-dynamic-viewer.Incoming .my-value .text{margin:-3px 5px 0}.my-dynamic-viewer.vertical{display:block}.my-dynamic-viewer.vertical .my-label{width:auto}.my-dynamic-viewer.vertical .my-value{width:auto}.my-dynamic-viewer.with-out-label{width:100%!important}.select-label{color:#8f98aa;font-size:12px;margin-bottom:0}.ng-select-container{border:none!important;background-color:#8f98aa1a!important;border-radius:5px!important;height:40px!important}.ng-select-container .ng-value-container{padding:5px 7px 0!important}.ng-select-container .ng-value-container .ng-placeholder{padding:0 5px}.ng-select-container .ng-value-container .ng-value{color:#495057}.ng-select-container .ng-arrow-wrapper{padding:0 20px}.ng-select-container .ng-input{left:10px;right:10px;width:auto}.ng-select-disabled .ng-select-container{background-color:#e9ecef!important}.ng-dropdown-panel .ng-dropdown-panel-items .ng-option .option-wrapper .check-box-wrapper{position:relative}.ng-dropdown-panel .ng-dropdown-panel-items .ng-option .option-wrapper .check-box-wrapper input{visibility:hidden;width:20px;height:20px}.ng-dropdown-panel .ng-dropdown-panel-items .ng-option .option-wrapper .check-box-wrapper .icon-wrapper{position:absolute;top:0px;left:0px;width:20px;height:20px;border:1px solid #2e62df;display:flex;justify-content:center;align-items:center}.ng-dropdown-panel .ng-dropdown-panel-items .ng-option .option-wrapper .check-box-wrapper .icon-wrapper .icon{color:#2e62df;display:none;justify-content:center;align-items:center;font-weight:bold}.ng-dropdown-panel .ng-dropdown-panel-items .ng-option-selected .option-wrapper .check-box-wrapper .icon-wrapper .icon{display:flex}.ng-dropdown-panel .ng-dropdown-panel-items .ng-option-selected .option-wrapper .label-wrapper{color:#2e62df}.ng-select .ng-select-focused:not(.ng-select-opened) .ng-select-container{border-color:#ccc;box-shadow:none}\n"], components: [{ type: i2.NgSelectComponent, selector: "ng-select", inputs: ["markFirst", "dropdownPosition", "loading", "closeOnSelect", "hideSelected", "selectOnTab", "bufferAmount", "selectableGroup", "selectableGroupAsModel", "searchFn", "trackByFn", "clearOnBackspace", "labelForId", "inputAttrs", "readonly", "searchWhileComposing", "minTermLength", "editableSearchTerm", "keyDownFn", "multiple", "addTag", "searchable", "clearable", "isOpen", "items", "compareWith", "clearSearchOnAdd", "bindLabel", "placeholder", "notFoundText", "typeToSearchText", "addTagText", "loadingText", "clearAllText", "virtualScroll", "openOnEnter", "appendTo", "bindValue", "appearance", "maxSelectedItems", "groupBy", "groupValue", "tabIndex", "typeahead"], outputs: ["blur", "focus", "change", "open", "close", "search", "clear", "add", "remove", "scroll", "scrollToEnd"] }], directives: [{ type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i2.ɵf, selector: "[ng-option-tmp]" }, { type: i4.CheckboxControlValueAccessor, selector: "input[type=checkbox][formControlName],input[type=checkbox][formControl],input[type=checkbox][ngModel]" }, { type: i2.ɵh, selector: "[ng-label-tmp]" }, { type: i2.ɵi, selector: "[ng-multi-label-tmp]" }, { type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "translate": i1.TranslatePipe }, encapsulation: i0.ViewEncapsulation.None });
81
+ ], usesOnChanges: true, ngImport: i0, template: "<ng-container *ngIf=\"label\">\r\n <div>\r\n <label class=\"select-label\"\r\n >{{ label | translate\r\n }}<span *ngIf=\"false\" class=\"text-danger m-1\">*</span></label\r\n >\r\n </div>\r\n</ng-container>\r\n<ng-select\r\n [items]=\"buffer\"\r\n [bindLabel]=\"bindLabel\"\r\n [bindValue]=\"bindValue\"\r\n [placeholder]=\"placeholder\"\r\n [multiple]=\"multiple\"\r\n [searchable]=\"searchable\"\r\n [closeOnSelect]=\"closeOnSelect\"\r\n [hideSelected]=\"hideSelectedItems\"\r\n [loading]=\"loading\"\r\n (scrollToEnd)=\"onScrollToEnd()\"\r\n (change)=\"emitSelection($event)\"\r\n [disabled]=\"disabled\"\r\n [(ngModel)]=\"selection\"\r\n>\r\n <!-- template for viewing options in single and multi select -->\r\n <ng-template\r\n ng-option-tmp\r\n let-item=\"item\"\r\n let-item$=\"item$\"\r\n let-index=\"index\"\r\n >\r\n <div class=\"option-wrapper\">\r\n <span class=\"check-box-wrapper\" *ngIf=\"multiple\">\r\n <input\r\n id=\"item-{{ index }}\"\r\n type=\"checkbox\"\r\n [ngModel]=\"item$.selected\"\r\n />\r\n <span class=\"icon-wrapper\">\r\n <span class=\"bi bi-check2 icon\"></span>\r\n </span>\r\n </span>\r\n <span class=\"label-wrapper\">\r\n {{ item[bindLabel] | translate }}\r\n </span>\r\n </div>\r\n </ng-template>\r\n\r\n <!-- template for viewing single select selected value -->\r\n <ng-template ng-label-tmp let-item=\"item\">\r\n {{ (bindLabel ? item[bindLabel] : item) | translate }}\r\n </ng-template>\r\n\r\n <!-- template for viewing multi select selected values -->\r\n <ng-template ng-multi-label-tmp let-items=\"items\" let-clear=\"clear\">\r\n <div class=\"ng-value\" *ngFor=\"let item of items ? items : []\">\r\n <span class=\"ng-value-label\">\r\n {{ (bindLabel ? item[bindLabel] : item) | translate }}\r\n </span>\r\n <span class=\"ng-value-icon right\" (click)=\"clear(item)\" aria-hidden=\"true\"\r\n >\u00D7</span\r\n >\r\n </div>\r\n </ng-template>\r\n</ng-select>\r\n", styles: [".bi{margin:0!important}.memo-sorting-wrapper{width:265px;margin:0 10px;height:100%;display:flex}.memo-sorting-wrapper .sorting-direction{width:65px;height:40px;background-color:#465573;color:#fff;font-size:20px;display:flex;justify-content:center;align-items:center;cursor:pointer}.memo-sorting-wrapper .memo-sorting-trigger{width:calc(100% - 65px);height:100%;background-color:transparent;border:1px solid lightgrey;display:flex;justify-content:space-between;align-items:center;padding:0 15px;font-size:14px}.memo-sorting-wrapper .memo-sorting-trigger i{font-size:16px;color:gray}.memo-sorting-menu{width:200px}.my-button{border:1px solid #465573;color:#465573;border-radius:5px;background-color:transparent;font-weight:bold;min-width:80px;height:40px}.my-button.reset{border:none}.my-button:hover{color:#fff;background-color:#465573}.my-button:hover.reset{color:#465573;border:1px solid #465573;background-color:#fff}.app-property-value .app-input-wrapper label{color:#646f85;font-size:13px;margin-bottom:5px}.app-property-value .app-input-wrapper label .text-danger{font-size:16px;line-height:14px;margin:0 5px!important}.app-property-value .app-input-wrapper .form-control{border:1px solid #ccc;border-radius:5px;background-color:#8f98aa1a;height:40px}.app-property-value .app-input-wrapper .form-control:disabled{background-color:#e9ecef!important}.app-property-value .app-input-wrapper .form-control:focus{border:1px solid #1a96c6;box-shadow:0 0 4px #79c3c26b!important}.app-property-value .app-input-wrapper .app-textitem-editable-error .error-containers{list-style:none;padding:0;margin:0;font-size:14px}.app-property-value .app-input-wrapper .app-textitem-editable-error .error-containers .error{margin-top:5px}.autocomplete-container .input-container input:focus,hijri-gregorian-datepicker .form-group .input-group .form-control:focus,.ng-select.ng-select-focused .ng-select-container{border:1px solid #1a96c6!important;box-shadow:0 0 4px #79c3c26b!important}input::placeholder{font-size:12px}.form-control:focus{box-shadow:none!important}.mat-stepper-horizontal{margin-top:-25px}.mat-stepper-horizontal .mat-horizontal-stepper-header-container .mat-step-header.cdk-program-focused{background-color:transparent}.mat-stepper-horizontal .mat-horizontal-stepper-header-container .mat-step-header .mat-step-icon-selected{background-color:transparent;color:#fff;background-image:linear-gradient(to right,#0dbab5,#1a96c6)}@media only screen and (max-width: 576px){.mat-stepper-horizontal .mat-horizontal-stepper-header-container .mat-step-header .mat-step-label .mat-step-text-label{white-space:pre-wrap;overflow:visible}}.mat-stepper-horizontal .mat-horizontal-content-container{overflow:visible}@media only screen and (max-width: 768px){.mat-stepper-horizontal .mat-horizontal-content-container{padding:0 0 24px}}.mat-stepper-horizontal.rtl .mat-horizontal-stepper-header:first-child:after,.mat-stepper-horizontal.rtl .mat-horizontal-stepper-header:last-child:before{display:none}.mat-stepper-horizontal.rtl .mat-horizontal-stepper-header:first-child:before{border-top-width:1px;border-top-style:solid;content:\"\";display:inline-block;height:0;position:absolute;width:calc(50% - 20px);left:0}.mat-stepper-horizontal.rtl .mat-horizontal-stepper-header:last-child:after{border-top-width:1px;border-top-style:solid;content:\"\";display:inline-block;height:0;position:absolute;width:calc(50% - 20px);right:0}.form-wrapper{padding:30px 15px;border:1px solid #dde0e2}.form-wrapper .buttons-wrapper{display:flex;justify-content:space-between}.form-wrapper .buttons-wrapper .action-buttons-wrapper{display:flex}.form-wrapper .buttons-wrapper button{background-image:linear-gradient(to right,#0dbab5,#1a96c6);height:40px;color:#fff;border:none;width:125px;margin-top:20px;border-radius:5px}.form-wrapper .buttons-wrapper button:disabled{opacity:.4;cursor:not-allowed}.form-wrapper .buttons-wrapper button:hover{opacity:.7}.form-wrapper .upload-wrapper{display:flex;flex-direction:column;justify-content:flex-end}.form-wrapper .upload-wrapper label{color:#8f98aa;font-size:14px}.form-wrapper .upload-wrapper button{padding:10px;border:1px solid lightgray}.form-wrapper .upload-wrapper button span{margin:0 10px}.my-dynamic-viewer{display:flex;align-items:center;font-size:12px;min-height:30px}.my-dynamic-viewer .my-label{font-size:12px;font-weight:500;width:150px;word-break:break-word}@media (max-width: 992px){.my-dynamic-viewer .my-label{width:50%}}.my-dynamic-viewer .my-value{width:calc(100% - 150px);word-break:break-word}@media (max-width: 992px){.my-dynamic-viewer .my-value{width:50%}}.my-dynamic-viewer .direction-img{font-size:14px}.my-dynamic-viewer .direction-img .incoming{display:none}.my-dynamic-viewer .direction-img .outgoing{display:none}.my-dynamic-viewer .direction-img .internal{display:none}.my-dynamic-viewer.draft .my-value{color:#596973}.my-dynamic-viewer.inProgress .my-value{color:#3c3cf0}.my-dynamic-viewer.registered .my-value{color:#4f008c}.my-dynamic-viewer.archived .my-value{color:#fbb62c}.my-dynamic-viewer.closed .my-value{color:#00dca5}.my-dynamic-viewer.approved .my-value{color:#06a57e}.my-dynamic-viewer.assigned .my-value{color:#fd6670}.my-dynamic-viewer.sent .my-value{color:#3c3cf0}.my-dynamic-viewer.published .my-value{color:#00dca5}.my-dynamic-viewer.Outgoing .my-value{display:flex}.my-dynamic-viewer.Outgoing .my-value .direction-img .outgoing{color:#fbb62c;margin:1px 5px;display:flex}.my-dynamic-viewer.Outgoing .my-value .text{margin:0 5px}.my-dynamic-viewer.Internal .my-value{display:flex}.my-dynamic-viewer.Internal .my-value .direction-img .internal{color:#3c3cf0;margin:1px 5px;display:flex}.my-dynamic-viewer.Internal .my-value .text{margin:0 5px}.my-dynamic-viewer.Incoming .my-value{display:flex}.my-dynamic-viewer.Incoming .my-value .direction-img .incoming{color:#00dca5;display:flex}.my-dynamic-viewer.Incoming .my-value .text{margin:-3px 5px 0}.my-dynamic-viewer.vertical{display:block}.my-dynamic-viewer.vertical .my-label{width:auto}.my-dynamic-viewer.vertical .my-value{width:auto}.my-dynamic-viewer.with-out-label{width:100%!important}.select-label{color:#8f98aa;font-size:12px;margin-bottom:0}.ng-select-container{border:none!important;background-color:#8f98aa1a!important;border-radius:5px!important;height:40px!important}.ng-select-container .ng-value-container{padding:5px 7px 0!important}.ng-select-container .ng-value-container .ng-placeholder{padding:0 5px}.ng-select-container .ng-value-container .ng-value{color:#495057}.ng-select-container .ng-arrow-wrapper{padding:0 20px}.ng-select-container .ng-input{left:10px;right:10px;width:auto}.ng-select-disabled .ng-select-container{background-color:#e9ecef!important}.ng-dropdown-panel .ng-dropdown-panel-items .ng-option .option-wrapper .check-box-wrapper{position:relative}.ng-dropdown-panel .ng-dropdown-panel-items .ng-option .option-wrapper .check-box-wrapper input{visibility:hidden;width:20px;height:20px}.ng-dropdown-panel .ng-dropdown-panel-items .ng-option .option-wrapper .check-box-wrapper .icon-wrapper{position:absolute;top:0px;left:0px;width:20px;height:20px;border:1px solid #2e62df;display:flex;justify-content:center;align-items:center}.ng-dropdown-panel .ng-dropdown-panel-items .ng-option .option-wrapper .check-box-wrapper .icon-wrapper .icon{color:#2e62df;display:none;justify-content:center;align-items:center;font-weight:bold}.ng-dropdown-panel .ng-dropdown-panel-items .ng-option-selected .option-wrapper .check-box-wrapper .icon-wrapper .icon{display:flex}.ng-dropdown-panel .ng-dropdown-panel-items .ng-option-selected .option-wrapper .label-wrapper{color:#2e62df}.ng-select .ng-select-focused:not(.ng-select-opened) .ng-select-container{border-color:#ccc;box-shadow:none}\n"], components: [{ type: i2.NgSelectComponent, selector: "ng-select", inputs: ["markFirst", "dropdownPosition", "loading", "closeOnSelect", "hideSelected", "selectOnTab", "bufferAmount", "selectableGroup", "selectableGroupAsModel", "searchFn", "trackByFn", "clearOnBackspace", "labelForId", "inputAttrs", "readonly", "searchWhileComposing", "minTermLength", "editableSearchTerm", "keyDownFn", "multiple", "addTag", "searchable", "clearable", "isOpen", "items", "compareWith", "clearSearchOnAdd", "bindLabel", "placeholder", "notFoundText", "typeToSearchText", "addTagText", "loadingText", "clearAllText", "virtualScroll", "openOnEnter", "appendTo", "bindValue", "appearance", "maxSelectedItems", "groupBy", "groupValue", "tabIndex", "typeahead"], outputs: ["blur", "focus", "change", "open", "close", "search", "clear", "add", "remove", "scroll", "scrollToEnd"] }], directives: [{ type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i2.ɵf, selector: "[ng-option-tmp]" }, { type: i4.CheckboxControlValueAccessor, selector: "input[type=checkbox][formControlName],input[type=checkbox][formControl],input[type=checkbox][ngModel]" }, { type: i2.ɵh, selector: "[ng-label-tmp]" }, { type: i2.ɵi, selector: "[ng-multi-label-tmp]" }, { type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "translate": i1.TranslatePipe }, encapsulation: i0.ViewEncapsulation.None });
82
82
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: SelectComponent, decorators: [{
83
83
  type: Component,
84
84
  args: [{