@eqproject/eqp-attachments 2.1.4 → 2.5.0

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 (27) hide show
  1. package/{esm2020 → esm2022}/eqproject-eqp-attachments.mjs +4 -4
  2. package/esm2022/lib/eqp-attachments.component.mjs +1096 -0
  3. package/{esm2020 → esm2022}/lib/eqp-attachments.module.mjs +43 -43
  4. package/esm2022/lib/helpers/attachment.helper.mjs +66 -0
  5. package/{esm2020 → esm2022}/lib/interfaces/IAttachment.mjs +11 -11
  6. package/{esm2020 → esm2022}/lib/interfaces/IOptions.mjs +1 -1
  7. package/{esm2020 → esm2022}/lib/modules/material.module.mjs +231 -231
  8. package/{esm2020 → esm2022}/lib/services/eqp-attachment-dialog.service.mjs +103 -103
  9. package/{esm2020 → esm2022}/lib/services/eqp-attachment.service.mjs +23 -23
  10. package/{esm2020 → esm2022}/public-api.mjs +9 -9
  11. package/{fesm2020 → fesm2022}/eqproject-eqp-attachments.mjs +1491 -1459
  12. package/{fesm2020 → fesm2022}/eqproject-eqp-attachments.mjs.map +1 -1
  13. package/index.d.ts +5 -5
  14. package/lib/eqp-attachments.component.d.ts +318 -318
  15. package/lib/eqp-attachments.module.d.ts +13 -13
  16. package/lib/helpers/attachment.helper.d.ts +20 -20
  17. package/lib/interfaces/IAttachment.d.ts +21 -21
  18. package/lib/interfaces/IOptions.d.ts +11 -11
  19. package/lib/modules/material.module.d.ts +37 -37
  20. package/lib/services/eqp-attachment-dialog.service.d.ts +31 -31
  21. package/lib/services/eqp-attachment.service.d.ts +7 -7
  22. package/package.json +13 -19
  23. package/public-api.d.ts +6 -6
  24. package/esm2020/lib/eqp-attachments.component.mjs +0 -1064
  25. package/esm2020/lib/helpers/attachment.helper.mjs +0 -66
  26. package/fesm2015/eqproject-eqp-attachments.mjs +0 -1535
  27. package/fesm2015/eqproject-eqp-attachments.mjs.map +0 -1
@@ -1,318 +1,318 @@
1
- import { HttpClient } from "@angular/common/http";
2
- import { ChangeDetectorRef, EventEmitter, OnInit, TemplateRef } from "@angular/core";
3
- import { FormBuilder, FormGroup } from "@angular/forms";
4
- import { MatDialog, MatDialogRef } from "@angular/material/dialog";
5
- import { DomSanitizer } from "@angular/platform-browser";
6
- import { ConfigColumn, EqpTableComponent, TooltipPositionType } from "@eqproject/eqp-table";
7
- import { ImageCroppedEvent, ImageCropperComponent, ImageTransform } from "ngx-image-cropper";
8
- import { AttachmentType, CropOptionEnum, IAttachmentDTO } from "./interfaces/IAttachment";
9
- import { IOptions } from "./interfaces/IOptions";
10
- import { EqpAttachmentService } from "./services/eqp-attachment.service";
11
- import * as i0 from "@angular/core";
12
- export declare class EqpAttachmentsComponent implements OnInit {
13
- private dialog;
14
- private formBuilder;
15
- private sanitizer;
16
- private http;
17
- private cd;
18
- private eqpAttachmentService;
19
- /**
20
- * Se TRUE allora nasconde la colonna per le azioni sull'allegato (nel caso "multipleAttachment" è TRUE).
21
- */
22
- disableAction: boolean;
23
- /**
24
- * Se TRUE mostra il titolo nell'header nel caso in cui "multipleAttachment" è TRUE ("Elenco allegati" di default).
25
- */
26
- showHeader: boolean;
27
- /**
28
- * Titolo da visualizzare se il parametro "showHeader" è TRUE. Di devault viene visualizzato "Elenco allegati".
29
- */
30
- headerTitle: string;
31
- /**
32
- * Sorgente dati da visualizzare. Nel caso si vuole gestire un singolo allegato va passato in ogni caso come Array.
33
- */
34
- attachmentsList: Array<IAttachmentDTO>;
35
- /**
36
- * Se TRUE non mostra la MatCard (nel caso in cui "multipleAttachment" è TRUE).
37
- */
38
- showMatCard: boolean;
39
- /**
40
- * Se FALSE allora il componente mostra solo il pulsante di caricamento di un singolo file, una volta caricato il file invoca l'evento di output "localEditedAttachments".
41
- * Se TRUE allora il componente mostra l'elenco di tutti gli allegati ricevuto nel parametro "attachmentsList".
42
- */
43
- multipleAttachment: boolean;
44
- /**
45
- * Se assume il valore TRUE allora sarà possibile caricare più file per volta. Questa funzionalità è attiva
46
- * SOLO se si gestiscono allegati multipli, quindi se l'input 'multipleAttachment' assume il valore TRUE, altrimenti è sempre disabilitata.
47
- */
48
- loadMultipleFiles: boolean;
49
- /**
50
- * Configurazione delle colonne della eqp-table per la visualizzazione degli allegati (caso "multipleAttachment" è TRUE).
51
- */
52
- attachmentsColumns: Array<ConfigColumn>;
53
- /**
54
- * Imposta il messaggio da visualizzare nel caso in cui la tabella degli allegati (nel caso in cui "multipleAttachment" è TRUE) è vuota.
55
- */
56
- emptyTableMessage: string;
57
- /**
58
- * Se TRUE allora permette di selezionare soltanto file di tipo immagine, avente uno dei mimetype
59
- * specificati dentro AttachmentHelperService.
60
- * Se FALSE permette di selezionare qualsiasi tipo di file
61
- */
62
- allowOnlyImages: boolean;
63
- /**
64
- * Specifica i tipi di file che è possibile caricare
65
- */
66
- acceptedFileTypes: string;
67
- /**
68
- * Se TRUE disabilita il pulsante di Aggiunta allegato (a prescindere dal valore del parametro "multipleAttachment").
69
- */
70
- isDisabled: boolean;
71
- /**
72
- * Mostra/nasconde la colonna per visualizzare l'anteprima dei file nella tabella (caso multipleAtatchments = true).
73
- */
74
- showInlinePreview: boolean;
75
- /**
76
- * Endpoint da chiamare per recueprare l'IAttachmentDTO completo da vedere nell'anteprima. La chiamata sarà in POST e nel body
77
- * conterrà l'IAttachmentDTO selezionato dall'utente.
78
- * La chiamata viene eseguita solo per l'anteprima delle immagini essendo necessario il base64 completo dell'immagine a dimensione reale.
79
- * Per documenti/link basta che sia popolata la proprietà FilePath di IAttachmentDTO.
80
- */
81
- getAttachmentEndpoint: string;
82
- /**
83
- * Hostname dell'ambiente di produzione dell'applicativo. Necessario per visualizzare l'anteprima dei documenti
84
- * tramite il viewer di google.
85
- * NOTA: Per visualizzare l'anteprima è necessario che la prorietà FilePath dell'IAttachmentDTO sia popolata e che
86
- * sia abilitato l'accesso alla cartella sul server tramite hostname.
87
- */
88
- productionBaseUrl: string;
89
- /**
90
- * Opzioni per la compressione delle immagini caricate.
91
- */
92
- compressionOptions: IOptions;
93
- /**
94
- * Array di AttachmentType che si possono aggiungere
95
- */
96
- allowedTypes: Array<AttachmentType>;
97
- /**
98
- * Permette di stabilire se la eqp-table contenente l'elenco degli allegati utilizza
99
- * il multilingua oppure no
100
- */
101
- isEqpTableMultiLanguage: boolean;
102
- /**
103
- * Permette di stabilire, in caso di gestione allegati multipli, se la tabella contenente l'elenco
104
- * degli allegati deve essere paginata oppure no
105
- */
106
- tablePaginatorVisible: boolean;
107
- /**
108
- * Permette di stabilire, in caso di gestione allegati multipli, se la tabella contenente l'elenco
109
- * degli allegati deve contenere il campo di ricerca oppure no
110
- */
111
- isTableSearcheable: boolean;
112
- /**
113
- * In caso di gestione allegati multipli, permette di stabilire la dimensione pagina di default
114
- * per la tabella contenente l'elenco degli allegati
115
- */
116
- tablePaginatorSize: number;
117
- /**
118
- * Permette di scegliere il modo in cui i file devono essere caricati
119
- */
120
- /**
121
- * Permette di stabilire se i pulsanti per il caricamento dei file sono separati o in un menù a tendina
122
- */
123
- separatedUploadButtons: boolean;
124
- /**
125
- * Permette di scegliere se dare la possibilità di vedere o no l'anteprima
126
- */
127
- showPreview: boolean;
128
- /**
129
- * In caso di allegato singolo, permette di scegliere se aggiungere file tramite drag and drop
130
- */
131
- singleAttachmentDragAndDrop: boolean;
132
- /**
133
- * Array di opzioni che si possono utilizzare per il crop
134
- */
135
- cropOptions: Array<CropOptionEnum>;
136
- /**
137
- * Classe custom da assegnare al dialog del crop immagini
138
- */
139
- cropDialogClass: string;
140
- /**
141
- * Input per definire le label da usare nel componente
142
- */
143
- downloadTooltipPosition: TooltipPositionType;
144
- openLinkLabel: string;
145
- addButtonLabel: string;
146
- downloadLabel: string;
147
- deleteLabel: string;
148
- fileNameLabel: string;
149
- previewLabel: string;
150
- uploadFileLabel: string;
151
- confirmLabel: string;
152
- abortLabel: string;
153
- saveLabel: string;
154
- exitLabel: string;
155
- uploadWithDropboxLabel: string;
156
- cropLabel: string;
157
- eqpTableSearchText: string;
158
- deleteDialogTitle: string;
159
- deleteDialogMessage: string;
160
- noImageSelectedErrorMessage: string;
161
- wrongTypeSelectedErrorMessage: string;
162
- videoPreviewErrorMessage: string;
163
- audioPreviewErrorMessage: string;
164
- flipHorinzontalLabel: string;
165
- flipVerticalLabel: string;
166
- rotateRightLabel: string;
167
- rotateLeftLabel: string;
168
- /**
169
- * Restituisce la lista aggiornata degli allegati.
170
- */
171
- localEditedAttachments: EventEmitter<Array<IAttachmentDTO>>;
172
- /**
173
- * Evento scatenato alla pressione del pulsante ESCI della modale di caricamento file.
174
- */
175
- abortAddAttachment: EventEmitter<any>;
176
- /**
177
- * Evento di output che restituisce l'IAttachmentDTO selezionato per il download nel caso FileDataBase64, FileContentType o FileName non fossero specificati.
178
- */
179
- downloadAttachment: EventEmitter<IAttachmentDTO>;
180
- /**
181
- * Evento di output che restituisce l'elemento eliminato prima che questo venga effettivamente rismosso dalla lista.
182
- */
183
- onDeleteAttachment: EventEmitter<IAttachmentDTO>;
184
- newAttachment: IAttachmentDTO;
185
- newMultipleAttachments: Array<IAttachmentDTO>;
186
- attachmentType: typeof AttachmentType;
187
- newAttachmentForm: FormGroup;
188
- selectedFile: File;
189
- selectedFiles: Array<File>;
190
- showCropImage: boolean;
191
- dialogAddAttachment: TemplateRef<any>;
192
- dialogRefAddAttachment: MatDialogRef<TemplateRef<any>>;
193
- dialogAddMultipleAttachment: TemplateRef<any>;
194
- dialogRefCropImage: MatDialogRef<TemplateRef<any>>;
195
- dialogCropImage: TemplateRef<any>;
196
- imageChangedEvent: any;
197
- croppedImage: any;
198
- transform: ImageTransform;
199
- canvasRotation: number;
200
- imageCropper: ImageCropperComponent;
201
- imageInput: any;
202
- AttachmentType: typeof AttachmentType;
203
- selectedAttachment: IAttachmentDTO;
204
- originalWidth: number;
205
- originalHeight: number;
206
- customWidth: number;
207
- customHeight: number;
208
- attachmentTable: EqpTableComponent;
209
- inlinePreviewTemplate: TemplateRef<any>;
210
- dialogPreview: TemplateRef<any>;
211
- imageFile: File;
212
- addingLinkMode: boolean;
213
- constructor(dialog: MatDialog, formBuilder: FormBuilder, sanitizer: DomSanitizer, http: HttpClient, cd: ChangeDetectorRef, eqpAttachmentService: EqpAttachmentService);
214
- ngOnInit(): Promise<void>;
215
- reloadData(): void;
216
- checkAttachmentImage(): void;
217
- /**
218
- * Configura le colonne per l'eqp-table nel caso in cui il parametro "multipleAttachments" è TRUE.
219
- */
220
- configureColumns(): void;
221
- /**
222
- * Elimina un allegato eliminando anche il file presente nello storage di archiviazione utilizzato (AWS o cartella progetto)
223
- * @param element IAttachmentDTO da cancellare
224
- */
225
- deleteAttachment(element: IAttachmentDTO): void;
226
- /**
227
- * Rimuove l'allegato selezionato dalla lista "attachmentsList" e invoca l'evento di output che restituisce la lista aggiornata.
228
- * @param attachmentIndex Indice dell'attachment da rimuovere
229
- */
230
- removeAttachmentFromList(attachmentIndex: number): void;
231
- /**
232
- * Scarica l'allegato o apre il link
233
- * @param element Allegato da mostrare
234
- */
235
- viewAttachment(attachment: IAttachmentDTO): void;
236
- /**
237
- * Ridefinisce l'icona da mostrare nella colonna dell'eqp-table per ogni file.
238
- * L'icona varia in base all'estensione del file
239
- * @param attachment
240
- */
241
- getAttachmentIcon(attachment: IAttachmentDTO): string;
242
- /**
243
- * In caso di allegato singolo, sceglie quale metodo richiamare in base al tipo di allegato
244
- */
245
- addFile(attachmentType: AttachmentType, imageInput?: any): void;
246
- createAttachmentForm(): void;
247
- close(emitCloseEvent?: boolean): void;
248
- /**
249
- * In base al tipo di allegato controlla se disabilitare o meno il pulsante per salvare.
250
- * Funzione usata nel [disable] del pulsante "Salva" del dialog per l'aggiunta di un allegato.
251
- * @returns
252
- */
253
- disableSave(): boolean;
254
- confirmAddAttachment(): void;
255
- /**
256
- * Apre il dialog per l'anteprima dell'allegato selezionato.
257
- * @param row
258
- * @returns
259
- */
260
- openPreviewDialog(row: IAttachmentDTO): Promise<void>;
261
- getAttachmentByID(): Promise<IAttachmentDTO>;
262
- /**
263
- * Evento scatenato alla selezione del file (o dei file).
264
- * Se il caricamento è SINGOLO o se comunque è stato selezionato un solo file allora si occupa di controllare se si tratta di un immagine in modo da
265
- * mostrare le funzionalità del croppie (per ritagliare l'immagine) oppure no.
266
- * Se il file caricato non è un immagine allora genera direttamente il base64 e lo associa all'allegato da salvare.
267
- * Se invece il caricamento dei file è MULTIPLO e sono presenti più file allora esegue le stesse operazioni ignorando però il contrllo
268
- * immagine per il croppie (in caso di caricamento multiplo le funzionalità del croppie sono disabilitate).
269
- */
270
- onFileAdded(event: any, isFileDropped?: boolean): Promise<void>;
271
- /**
272
- * A partire dal FILE ricevuto in input ricostruisce l'oggetto IAttachmentDTO e lo restituisce.
273
- * Se il parametro getBase64 viene passato a TRUE allora, sempre a partire dal file,genera il base64 e
274
- * ricava il ContentType da associare all'oggetto IAttachmentDTO da restituire
275
- * @param currentFile Oggetto FILE da processare
276
- * @param getBase64 Se TRUE allora calcola base64 e ContentType del file passato in input
277
- * @returns Restituisce un oggetto di tipo IAttachmentDTO
278
- */
279
- private createAttachmentFromUploadedFile;
280
- /**
281
- * A partire dal file passato in input restituisce un oggetto
282
- * contenente il base64 del file e il suo contentType
283
- * @param currentFile Oggetto File da cui estrapolare base64 e contentType
284
- * @returns Restituisce un oggetto avente le proprietà Base64File e ContentType
285
- */
286
- private getBase64FromFile;
287
- /**
288
- * Controlla se il file che si sta caricando è supportato dal sistema.
289
- * @returns
290
- */
291
- private checkAcceptedFiles;
292
- /**
293
- * Se eqp-attachments è stata configurata per il caricamento delle sole immagini allora verifica che il file passato in
294
- * input sia effettivamente un immagine o no.
295
- * Se il controllo va a buon fine restituisce TRUE altrimenti mostra un messaggio d'errore e restituisce FALSE
296
- */
297
- private checkAllowOnlyImageFile;
298
- getImageDimensions(img: any): void;
299
- restoreOriginalDimensions(): void;
300
- onDimensionsChange(dimension: string): void;
301
- imageCropped(event: ImageCroppedEvent): void;
302
- getCroppedAndUpload(file: any, newAttachment: IAttachmentDTO): void;
303
- rotateLeft(): void;
304
- rotateRight(): void;
305
- private flipAfterRotate;
306
- flipHorizontal(): void;
307
- flipVertical(): void;
308
- /**
309
- * Annulla la selezione del file, svuotando l'input e resettando tutte le proprietà dell'IAttachmentDTO
310
- */
311
- abortFile(): void;
312
- fileDropped(files: any): void;
313
- chooseDropboxFile(): void;
314
- onSelectFile(event: any, fileInput: any): void;
315
- switchToAddingLinkMode(): void;
316
- static ɵfac: i0.ɵɵFactoryDeclaration<EqpAttachmentsComponent, never>;
317
- static ɵcmp: i0.ɵɵComponentDeclaration<EqpAttachmentsComponent, "eqp-attachments", never, { "disableAction": "disableAction"; "showHeader": "showHeader"; "headerTitle": "headerTitle"; "attachmentsList": "attachmentsList"; "showMatCard": "showMatCard"; "multipleAttachment": "multipleAttachment"; "loadMultipleFiles": "loadMultipleFiles"; "attachmentsColumns": "attachmentsColumns"; "emptyTableMessage": "emptyTableMessage"; "allowOnlyImages": "allowOnlyImages"; "acceptedFileTypes": "acceptedFileTypes"; "isDisabled": "isDisabled"; "showInlinePreview": "showInlinePreview"; "getAttachmentEndpoint": "getAttachmentEndpoint"; "productionBaseUrl": "productionBaseUrl"; "compressionOptions": "compressionOptions"; "allowedTypes": "allowedTypes"; "isEqpTableMultiLanguage": "isEqpTableMultiLanguage"; "tablePaginatorVisible": "tablePaginatorVisible"; "isTableSearcheable": "isTableSearcheable"; "tablePaginatorSize": "tablePaginatorSize"; "separatedUploadButtons": "separatedUploadButtons"; "showPreview": "showPreview"; "singleAttachmentDragAndDrop": "singleAttachmentDragAndDrop"; "cropOptions": "cropOptions"; "cropDialogClass": "cropDialogClass"; "downloadTooltipPosition": "downloadTooltipPosition"; "openLinkLabel": "openLinkLabel"; "addButtonLabel": "addButtonLabel"; "downloadLabel": "downloadLabel"; "deleteLabel": "deleteLabel"; "fileNameLabel": "fileNameLabel"; "previewLabel": "previewLabel"; "uploadFileLabel": "uploadFileLabel"; "confirmLabel": "confirmLabel"; "abortLabel": "abortLabel"; "saveLabel": "saveLabel"; "exitLabel": "exitLabel"; "uploadWithDropboxLabel": "uploadWithDropboxLabel"; "cropLabel": "cropLabel"; "eqpTableSearchText": "eqpTableSearchText"; "deleteDialogTitle": "deleteDialogTitle"; "deleteDialogMessage": "deleteDialogMessage"; "noImageSelectedErrorMessage": "noImageSelectedErrorMessage"; "wrongTypeSelectedErrorMessage": "wrongTypeSelectedErrorMessage"; "videoPreviewErrorMessage": "videoPreviewErrorMessage"; "audioPreviewErrorMessage": "videoPreviewErrorMessage"; "flipHorinzontalLabel": "flipHorinzontalLabel"; "flipVerticalLabel": "flipVerticalLabel"; "rotateRightLabel": "rotateRightLabel"; "rotateLeftLabel": "rotateLeftLabel"; }, { "localEditedAttachments": "localEditedAttachments"; "abortAddAttachment": "abortAddAttachment"; "downloadAttachment": "downloadAttachment"; "onDeleteAttachment": "onDeleteAttachment"; }, never, never, false, never>;
318
- }
1
+ import { HttpClient } from "@angular/common/http";
2
+ import { ChangeDetectorRef, EventEmitter, OnInit, TemplateRef } from "@angular/core";
3
+ import { FormBuilder, FormGroup } from "@angular/forms";
4
+ import { MatDialog, MatDialogRef } from "@angular/material/dialog";
5
+ import { DomSanitizer } from "@angular/platform-browser";
6
+ import { ConfigColumn, EqpTableComponent, TooltipPositionType } from "@eqproject/eqp-table";
7
+ import { ImageCroppedEvent, ImageCropperComponent, ImageTransform } from "ngx-image-cropper";
8
+ import { AttachmentType, CropOptionEnum, IAttachmentDTO } from "./interfaces/IAttachment";
9
+ import { IOptions } from "./interfaces/IOptions";
10
+ import { EqpAttachmentService } from "./services/eqp-attachment.service";
11
+ import * as i0 from "@angular/core";
12
+ export declare class EqpAttachmentsComponent implements OnInit {
13
+ private dialog;
14
+ private formBuilder;
15
+ private sanitizer;
16
+ private http;
17
+ private cd;
18
+ private eqpAttachmentService;
19
+ /**
20
+ * Se TRUE allora nasconde la colonna per le azioni sull'allegato (nel caso "multipleAttachment" è TRUE).
21
+ */
22
+ disableAction: boolean;
23
+ /**
24
+ * Se TRUE mostra il titolo nell'header nel caso in cui "multipleAttachment" è TRUE ("Elenco allegati" di default).
25
+ */
26
+ showHeader: boolean;
27
+ /**
28
+ * Titolo da visualizzare se il parametro "showHeader" è TRUE. Di devault viene visualizzato "Elenco allegati".
29
+ */
30
+ headerTitle: string;
31
+ /**
32
+ * Sorgente dati da visualizzare. Nel caso si vuole gestire un singolo allegato va passato in ogni caso come Array.
33
+ */
34
+ attachmentsList: Array<IAttachmentDTO>;
35
+ /**
36
+ * Se TRUE non mostra la MatCard (nel caso in cui "multipleAttachment" è TRUE).
37
+ */
38
+ showMatCard: boolean;
39
+ /**
40
+ * Se FALSE allora il componente mostra solo il pulsante di caricamento di un singolo file, una volta caricato il file invoca l'evento di output "localEditedAttachments".
41
+ * Se TRUE allora il componente mostra l'elenco di tutti gli allegati ricevuto nel parametro "attachmentsList".
42
+ */
43
+ multipleAttachment: boolean;
44
+ /**
45
+ * Se assume il valore TRUE allora sarà possibile caricare più file per volta. Questa funzionalità è attiva
46
+ * SOLO se si gestiscono allegati multipli, quindi se l'input 'multipleAttachment' assume il valore TRUE, altrimenti è sempre disabilitata.
47
+ */
48
+ loadMultipleFiles: boolean;
49
+ /**
50
+ * Configurazione delle colonne della eqp-table per la visualizzazione degli allegati (caso "multipleAttachment" è TRUE).
51
+ */
52
+ attachmentsColumns: Array<ConfigColumn>;
53
+ /**
54
+ * Imposta il messaggio da visualizzare nel caso in cui la tabella degli allegati (nel caso in cui "multipleAttachment" è TRUE) è vuota.
55
+ */
56
+ emptyTableMessage: string;
57
+ /**
58
+ * Se TRUE allora permette di selezionare soltanto file di tipo immagine, avente uno dei mimetype
59
+ * specificati dentro AttachmentHelperService.
60
+ * Se FALSE permette di selezionare qualsiasi tipo di file
61
+ */
62
+ allowOnlyImages: boolean;
63
+ /**
64
+ * Specifica i tipi di file che è possibile caricare
65
+ */
66
+ acceptedFileTypes: string;
67
+ /**
68
+ * Se TRUE disabilita il pulsante di Aggiunta allegato (a prescindere dal valore del parametro "multipleAttachment").
69
+ */
70
+ isDisabled: boolean;
71
+ /**
72
+ * Mostra/nasconde la colonna per visualizzare l'anteprima dei file nella tabella (caso multipleAtatchments = true).
73
+ */
74
+ showInlinePreview: boolean;
75
+ /**
76
+ * Endpoint da chiamare per recueprare l'IAttachmentDTO completo da vedere nell'anteprima. La chiamata sarà in POST e nel body
77
+ * conterrà l'IAttachmentDTO selezionato dall'utente.
78
+ * La chiamata viene eseguita solo per l'anteprima delle immagini essendo necessario il base64 completo dell'immagine a dimensione reale.
79
+ * Per documenti/link basta che sia popolata la proprietà FilePath di IAttachmentDTO.
80
+ */
81
+ getAttachmentEndpoint: string;
82
+ /**
83
+ * Hostname dell'ambiente di produzione dell'applicativo. Necessario per visualizzare l'anteprima dei documenti
84
+ * tramite il viewer di google.
85
+ * NOTA: Per visualizzare l'anteprima è necessario che la prorietà FilePath dell'IAttachmentDTO sia popolata e che
86
+ * sia abilitato l'accesso alla cartella sul server tramite hostname.
87
+ */
88
+ productionBaseUrl: string;
89
+ /**
90
+ * Opzioni per la compressione delle immagini caricate.
91
+ */
92
+ compressionOptions: IOptions;
93
+ /**
94
+ * Array di AttachmentType che si possono aggiungere
95
+ */
96
+ allowedTypes: Array<AttachmentType>;
97
+ /**
98
+ * Permette di stabilire se la eqp-table contenente l'elenco degli allegati utilizza
99
+ * il multilingua oppure no
100
+ */
101
+ isEqpTableMultiLanguage: boolean;
102
+ /**
103
+ * Permette di stabilire, in caso di gestione allegati multipli, se la tabella contenente l'elenco
104
+ * degli allegati deve essere paginata oppure no
105
+ */
106
+ tablePaginatorVisible: boolean;
107
+ /**
108
+ * Permette di stabilire, in caso di gestione allegati multipli, se la tabella contenente l'elenco
109
+ * degli allegati deve contenere il campo di ricerca oppure no
110
+ */
111
+ isTableSearcheable: boolean;
112
+ /**
113
+ * In caso di gestione allegati multipli, permette di stabilire la dimensione pagina di default
114
+ * per la tabella contenente l'elenco degli allegati
115
+ */
116
+ tablePaginatorSize: number;
117
+ /**
118
+ * Permette di scegliere il modo in cui i file devono essere caricati
119
+ */
120
+ /**
121
+ * Permette di stabilire se i pulsanti per il caricamento dei file sono separati o in un menù a tendina
122
+ */
123
+ separatedUploadButtons: boolean;
124
+ /**
125
+ * Permette di scegliere se dare la possibilità di vedere o no l'anteprima
126
+ */
127
+ showPreview: boolean;
128
+ /**
129
+ * In caso di allegato singolo, permette di scegliere se aggiungere file tramite drag and drop
130
+ */
131
+ singleAttachmentDragAndDrop: boolean;
132
+ /**
133
+ * Array di opzioni che si possono utilizzare per il crop
134
+ */
135
+ cropOptions: Array<CropOptionEnum>;
136
+ /**
137
+ * Classe custom da assegnare al dialog del crop immagini
138
+ */
139
+ cropDialogClass: string;
140
+ /**
141
+ * Input per definire le label da usare nel componente
142
+ */
143
+ downloadTooltipPosition: TooltipPositionType;
144
+ openLinkLabel: string;
145
+ addButtonLabel: string;
146
+ downloadLabel: string;
147
+ deleteLabel: string;
148
+ fileNameLabel: string;
149
+ previewLabel: string;
150
+ uploadFileLabel: string;
151
+ confirmLabel: string;
152
+ abortLabel: string;
153
+ saveLabel: string;
154
+ exitLabel: string;
155
+ uploadWithDropboxLabel: string;
156
+ cropLabel: string;
157
+ eqpTableSearchText: string;
158
+ deleteDialogTitle: string;
159
+ deleteDialogMessage: string;
160
+ noImageSelectedErrorMessage: string;
161
+ wrongTypeSelectedErrorMessage: string;
162
+ videoPreviewErrorMessage: string;
163
+ audioPreviewErrorMessage: string;
164
+ flipHorinzontalLabel: string;
165
+ flipVerticalLabel: string;
166
+ rotateRightLabel: string;
167
+ rotateLeftLabel: string;
168
+ /**
169
+ * Restituisce la lista aggiornata degli allegati.
170
+ */
171
+ localEditedAttachments: EventEmitter<Array<IAttachmentDTO>>;
172
+ /**
173
+ * Evento scatenato alla pressione del pulsante ESCI della modale di caricamento file.
174
+ */
175
+ abortAddAttachment: EventEmitter<any>;
176
+ /**
177
+ * Evento di output che restituisce l'IAttachmentDTO selezionato per il download nel caso FileDataBase64, FileContentType o FileName non fossero specificati.
178
+ */
179
+ downloadAttachment: EventEmitter<IAttachmentDTO>;
180
+ /**
181
+ * Evento di output che restituisce l'elemento eliminato prima che questo venga effettivamente rismosso dalla lista.
182
+ */
183
+ onDeleteAttachment: EventEmitter<IAttachmentDTO>;
184
+ newAttachment: IAttachmentDTO;
185
+ newMultipleAttachments: Array<IAttachmentDTO>;
186
+ attachmentType: typeof AttachmentType;
187
+ newAttachmentForm: FormGroup;
188
+ selectedFile: File;
189
+ selectedFiles: Array<File>;
190
+ showCropImage: boolean;
191
+ dialogAddAttachment: TemplateRef<any>;
192
+ dialogRefAddAttachment: MatDialogRef<TemplateRef<any>>;
193
+ dialogAddMultipleAttachment: TemplateRef<any>;
194
+ dialogRefCropImage: MatDialogRef<TemplateRef<any>>;
195
+ dialogCropImage: TemplateRef<any>;
196
+ imageChangedEvent: any;
197
+ croppedImage: any;
198
+ transform: ImageTransform;
199
+ canvasRotation: number;
200
+ imageCropper: ImageCropperComponent;
201
+ imageInput: any;
202
+ AttachmentType: typeof AttachmentType;
203
+ selectedAttachment: IAttachmentDTO;
204
+ originalWidth: number;
205
+ originalHeight: number;
206
+ customWidth: number;
207
+ customHeight: number;
208
+ attachmentTable: EqpTableComponent;
209
+ inlinePreviewTemplate: TemplateRef<any>;
210
+ dialogPreview: TemplateRef<any>;
211
+ imageFile: File;
212
+ addingLinkMode: boolean;
213
+ constructor(dialog: MatDialog, formBuilder: FormBuilder, sanitizer: DomSanitizer, http: HttpClient, cd: ChangeDetectorRef, eqpAttachmentService: EqpAttachmentService);
214
+ ngOnInit(): Promise<void>;
215
+ reloadData(): void;
216
+ checkAttachmentImage(): void;
217
+ /**
218
+ * Configura le colonne per l'eqp-table nel caso in cui il parametro "multipleAttachments" è TRUE.
219
+ */
220
+ configureColumns(): void;
221
+ /**
222
+ * Elimina un allegato eliminando anche il file presente nello storage di archiviazione utilizzato (AWS o cartella progetto)
223
+ * @param element IAttachmentDTO da cancellare
224
+ */
225
+ deleteAttachment(element: IAttachmentDTO): void;
226
+ /**
227
+ * Rimuove l'allegato selezionato dalla lista "attachmentsList" e invoca l'evento di output che restituisce la lista aggiornata.
228
+ * @param attachmentIndex Indice dell'attachment da rimuovere
229
+ */
230
+ removeAttachmentFromList(attachmentIndex: number): void;
231
+ /**
232
+ * Scarica l'allegato o apre il link
233
+ * @param element Allegato da mostrare
234
+ */
235
+ viewAttachment(attachment: IAttachmentDTO): void;
236
+ /**
237
+ * Ridefinisce l'icona da mostrare nella colonna dell'eqp-table per ogni file.
238
+ * L'icona varia in base all'estensione del file
239
+ * @param attachment
240
+ */
241
+ getAttachmentIcon(attachment: IAttachmentDTO): string;
242
+ /**
243
+ * In caso di allegato singolo, sceglie quale metodo richiamare in base al tipo di allegato
244
+ */
245
+ addFile(attachmentType: AttachmentType, imageInput?: any): void;
246
+ createAttachmentForm(): void;
247
+ close(emitCloseEvent?: boolean): void;
248
+ /**
249
+ * In base al tipo di allegato controlla se disabilitare o meno il pulsante per salvare.
250
+ * Funzione usata nel [disable] del pulsante "Salva" del dialog per l'aggiunta di un allegato.
251
+ * @returns
252
+ */
253
+ disableSave(): boolean;
254
+ confirmAddAttachment(): void;
255
+ /**
256
+ * Apre il dialog per l'anteprima dell'allegato selezionato.
257
+ * @param row
258
+ * @returns
259
+ */
260
+ openPreviewDialog(row: IAttachmentDTO): Promise<void>;
261
+ getAttachmentByID(): Promise<IAttachmentDTO>;
262
+ /**
263
+ * Evento scatenato alla selezione del file (o dei file).
264
+ * Se il caricamento è SINGOLO o se comunque è stato selezionato un solo file allora si occupa di controllare se si tratta di un immagine in modo da
265
+ * mostrare le funzionalità del croppie (per ritagliare l'immagine) oppure no.
266
+ * Se il file caricato non è un immagine allora genera direttamente il base64 e lo associa all'allegato da salvare.
267
+ * Se invece il caricamento dei file è MULTIPLO e sono presenti più file allora esegue le stesse operazioni ignorando però il contrllo
268
+ * immagine per il croppie (in caso di caricamento multiplo le funzionalità del croppie sono disabilitate).
269
+ */
270
+ onFileAdded(event: any, isFileDropped?: boolean): Promise<void>;
271
+ /**
272
+ * A partire dal FILE ricevuto in input ricostruisce l'oggetto IAttachmentDTO e lo restituisce.
273
+ * Se il parametro getBase64 viene passato a TRUE allora, sempre a partire dal file,genera il base64 e
274
+ * ricava il ContentType da associare all'oggetto IAttachmentDTO da restituire
275
+ * @param currentFile Oggetto FILE da processare
276
+ * @param getBase64 Se TRUE allora calcola base64 e ContentType del file passato in input
277
+ * @returns Restituisce un oggetto di tipo IAttachmentDTO
278
+ */
279
+ private createAttachmentFromUploadedFile;
280
+ /**
281
+ * A partire dal file passato in input restituisce un oggetto
282
+ * contenente il base64 del file e il suo contentType
283
+ * @param currentFile Oggetto File da cui estrapolare base64 e contentType
284
+ * @returns Restituisce un oggetto avente le proprietà Base64File e ContentType
285
+ */
286
+ private getBase64FromFile;
287
+ /**
288
+ * Controlla se il file che si sta caricando è supportato dal sistema.
289
+ * @returns
290
+ */
291
+ private checkAcceptedFiles;
292
+ /**
293
+ * Se eqp-attachments è stata configurata per il caricamento delle sole immagini allora verifica che il file passato in
294
+ * input sia effettivamente un immagine o no.
295
+ * Se il controllo va a buon fine restituisce TRUE altrimenti mostra un messaggio d'errore e restituisce FALSE
296
+ */
297
+ private checkAllowOnlyImageFile;
298
+ getImageDimensions(img: any): void;
299
+ restoreOriginalDimensions(): void;
300
+ onDimensionsChange(dimension: string): void;
301
+ imageCropped(event: ImageCroppedEvent): void;
302
+ getCroppedAndUpload(file: any, newAttachment: IAttachmentDTO): void;
303
+ rotateLeft(): void;
304
+ rotateRight(): void;
305
+ private flipAfterRotate;
306
+ flipHorizontal(): void;
307
+ flipVertical(): void;
308
+ /**
309
+ * Annulla la selezione del file, svuotando l'input e resettando tutte le proprietà dell'IAttachmentDTO
310
+ */
311
+ abortFile(): void;
312
+ fileDropped(files: any): void;
313
+ chooseDropboxFile(): void;
314
+ onSelectFile(event: any, fileInput: any): void;
315
+ switchToAddingLinkMode(): void;
316
+ static ɵfac: i0.ɵɵFactoryDeclaration<EqpAttachmentsComponent, never>;
317
+ static ɵcmp: i0.ɵɵComponentDeclaration<EqpAttachmentsComponent, "eqp-attachments", never, { "disableAction": { "alias": "disableAction"; "required": false; }; "showHeader": { "alias": "showHeader"; "required": false; }; "headerTitle": { "alias": "headerTitle"; "required": false; }; "attachmentsList": { "alias": "attachmentsList"; "required": false; }; "showMatCard": { "alias": "showMatCard"; "required": false; }; "multipleAttachment": { "alias": "multipleAttachment"; "required": false; }; "loadMultipleFiles": { "alias": "loadMultipleFiles"; "required": false; }; "attachmentsColumns": { "alias": "attachmentsColumns"; "required": false; }; "emptyTableMessage": { "alias": "emptyTableMessage"; "required": false; }; "allowOnlyImages": { "alias": "allowOnlyImages"; "required": false; }; "acceptedFileTypes": { "alias": "acceptedFileTypes"; "required": false; }; "isDisabled": { "alias": "isDisabled"; "required": false; }; "showInlinePreview": { "alias": "showInlinePreview"; "required": false; }; "getAttachmentEndpoint": { "alias": "getAttachmentEndpoint"; "required": false; }; "productionBaseUrl": { "alias": "productionBaseUrl"; "required": false; }; "compressionOptions": { "alias": "compressionOptions"; "required": false; }; "allowedTypes": { "alias": "allowedTypes"; "required": false; }; "isEqpTableMultiLanguage": { "alias": "isEqpTableMultiLanguage"; "required": false; }; "tablePaginatorVisible": { "alias": "tablePaginatorVisible"; "required": false; }; "isTableSearcheable": { "alias": "isTableSearcheable"; "required": false; }; "tablePaginatorSize": { "alias": "tablePaginatorSize"; "required": false; }; "separatedUploadButtons": { "alias": "separatedUploadButtons"; "required": false; }; "showPreview": { "alias": "showPreview"; "required": false; }; "singleAttachmentDragAndDrop": { "alias": "singleAttachmentDragAndDrop"; "required": false; }; "cropOptions": { "alias": "cropOptions"; "required": false; }; "cropDialogClass": { "alias": "cropDialogClass"; "required": false; }; "downloadTooltipPosition": { "alias": "downloadTooltipPosition"; "required": false; }; "openLinkLabel": { "alias": "openLinkLabel"; "required": false; }; "addButtonLabel": { "alias": "addButtonLabel"; "required": false; }; "downloadLabel": { "alias": "downloadLabel"; "required": false; }; "deleteLabel": { "alias": "deleteLabel"; "required": false; }; "fileNameLabel": { "alias": "fileNameLabel"; "required": false; }; "previewLabel": { "alias": "previewLabel"; "required": false; }; "uploadFileLabel": { "alias": "uploadFileLabel"; "required": false; }; "confirmLabel": { "alias": "confirmLabel"; "required": false; }; "abortLabel": { "alias": "abortLabel"; "required": false; }; "saveLabel": { "alias": "saveLabel"; "required": false; }; "exitLabel": { "alias": "exitLabel"; "required": false; }; "uploadWithDropboxLabel": { "alias": "uploadWithDropboxLabel"; "required": false; }; "cropLabel": { "alias": "cropLabel"; "required": false; }; "eqpTableSearchText": { "alias": "eqpTableSearchText"; "required": false; }; "deleteDialogTitle": { "alias": "deleteDialogTitle"; "required": false; }; "deleteDialogMessage": { "alias": "deleteDialogMessage"; "required": false; }; "noImageSelectedErrorMessage": { "alias": "noImageSelectedErrorMessage"; "required": false; }; "wrongTypeSelectedErrorMessage": { "alias": "wrongTypeSelectedErrorMessage"; "required": false; }; "videoPreviewErrorMessage": { "alias": "videoPreviewErrorMessage"; "required": false; }; "audioPreviewErrorMessage": { "alias": "videoPreviewErrorMessage"; "required": false; }; "flipHorinzontalLabel": { "alias": "flipHorinzontalLabel"; "required": false; }; "flipVerticalLabel": { "alias": "flipVerticalLabel"; "required": false; }; "rotateRightLabel": { "alias": "rotateRightLabel"; "required": false; }; "rotateLeftLabel": { "alias": "rotateLeftLabel"; "required": false; }; }, { "localEditedAttachments": "localEditedAttachments"; "abortAddAttachment": "abortAddAttachment"; "downloadAttachment": "downloadAttachment"; "onDeleteAttachment": "onDeleteAttachment"; }, never, never, false, never>;
318
+ }