@datarailsshared/datarailsshared 1.6.310 → 1.6.312

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 (25) hide show
  1. package/datarailsshared-datarailsshared-1.6.312.tgz +0 -0
  2. package/esm2022/lib/dr-chip/dr-chip.component.mjs +26 -10
  3. package/esm2022/lib/dr-file-upload/directives/drag-drop.directive.mjs +63 -0
  4. package/esm2022/lib/dr-file-upload/dr-file-upload-item/dr-file-upload-item.component.mjs +168 -0
  5. package/esm2022/lib/dr-file-upload/dr-file-upload.component.mjs +512 -0
  6. package/esm2022/lib/dr-file-upload/index.mjs +6 -0
  7. package/esm2022/lib/dr-file-upload/models/file-upload.models.mjs +2 -0
  8. package/esm2022/lib/dr-file-upload/services/file-upload-validation.service.mjs +76 -0
  9. package/esm2022/lib/dr-file-upload/templates/dr-file-upload-image-template/dr-file-upload-image-template.component.mjs +135 -0
  10. package/esm2022/lib/dr-progress-bar/dr-progress-bar.component.mjs +39 -8
  11. package/esm2022/local-api.mjs +2 -1
  12. package/fesm2022/datarailsshared-datarailsshared.mjs +1233 -256
  13. package/fesm2022/datarailsshared-datarailsshared.mjs.map +1 -1
  14. package/lib/dr-chip/dr-chip.component.d.ts +8 -5
  15. package/lib/dr-file-upload/directives/drag-drop.directive.d.ts +12 -0
  16. package/lib/dr-file-upload/dr-file-upload-item/dr-file-upload-item.component.d.ts +18 -0
  17. package/lib/dr-file-upload/dr-file-upload.component.d.ts +66 -0
  18. package/lib/dr-file-upload/index.d.ts +5 -0
  19. package/lib/dr-file-upload/models/file-upload.models.d.ts +13 -0
  20. package/lib/dr-file-upload/services/file-upload-validation.service.d.ts +16 -0
  21. package/lib/dr-file-upload/templates/dr-file-upload-image-template/dr-file-upload-image-template.component.d.ts +22 -0
  22. package/lib/dr-progress-bar/dr-progress-bar.component.d.ts +13 -4
  23. package/local-api.d.ts +1 -0
  24. package/package.json +1 -1
  25. package/datarailsshared-datarailsshared-1.6.310.tgz +0 -0
@@ -0,0 +1,512 @@
1
+ import { booleanAttribute, ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChild, ElementRef, EventEmitter, HostBinding, inject, Input, Output, TemplateRef, ViewChild, } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import { DrDragDropDirective } from './directives/drag-drop.directive';
4
+ import { DrFileUploadItemComponent } from './dr-file-upload-item/dr-file-upload-item.component';
5
+ import { DrButtonComponent } from '../dr-inputs/button/button.component';
6
+ import { FileUploadValidationService } from './services/file-upload-validation.service';
7
+ import * as i0 from "@angular/core";
8
+ import * as i1 from "@angular/common";
9
+ const _c0 = ["dropzoneTemplate"];
10
+ const _c1 = ["fileItemTemplate"];
11
+ const _c2 = ["browseButtonTemplate"];
12
+ const _c3 = ["uploadTemplate"];
13
+ const _c4 = ["fileInput"];
14
+ function DrFileUploadComponent_div_2_ng_container_1_ng_container_1_Template(rf, ctx) { if (rf & 1) {
15
+ i0.ɵɵelementContainer(0);
16
+ } }
17
+ function DrFileUploadComponent_div_2_ng_container_1_Template(rf, ctx) { if (rf & 1) {
18
+ i0.ɵɵelementContainerStart(0);
19
+ i0.ɵɵtemplate(1, DrFileUploadComponent_div_2_ng_container_1_ng_container_1_Template, 1, 0, "ng-container", 8);
20
+ i0.ɵɵelementContainerEnd();
21
+ } if (rf & 2) {
22
+ const ctx_r5 = i0.ɵɵnextContext(2);
23
+ i0.ɵɵadvance(1);
24
+ i0.ɵɵproperty("ngTemplateOutlet", ctx_r5.dropzoneTemplate);
25
+ } }
26
+ function DrFileUploadComponent_div_2_ng_template_2_span_4_Template(rf, ctx) { if (rf & 1) {
27
+ i0.ɵɵelementStart(0, "span", 15);
28
+ i0.ɵɵtext(1);
29
+ i0.ɵɵelementEnd();
30
+ } if (rf & 2) {
31
+ const ctx_r9 = i0.ɵɵnextContext(3);
32
+ i0.ɵɵadvance(1);
33
+ i0.ɵɵtextInterpolate(ctx_r9.computedDropzoneSubtext);
34
+ } }
35
+ function DrFileUploadComponent_div_2_ng_template_2_ng_container_7_ng_container_1_Template(rf, ctx) { if (rf & 1) {
36
+ i0.ɵɵelementContainer(0);
37
+ } }
38
+ function DrFileUploadComponent_div_2_ng_template_2_ng_container_7_Template(rf, ctx) { if (rf & 1) {
39
+ i0.ɵɵelementContainerStart(0);
40
+ i0.ɵɵtemplate(1, DrFileUploadComponent_div_2_ng_template_2_ng_container_7_ng_container_1_Template, 1, 0, "ng-container", 8);
41
+ i0.ɵɵelementContainerEnd();
42
+ } if (rf & 2) {
43
+ const ctx_r10 = i0.ɵɵnextContext(3);
44
+ i0.ɵɵadvance(1);
45
+ i0.ɵɵproperty("ngTemplateOutlet", ctx_r10.browseButtonTemplate);
46
+ } }
47
+ function DrFileUploadComponent_div_2_ng_template_2_ng_template_8_Template(rf, ctx) { if (rf & 1) {
48
+ const _r15 = i0.ɵɵgetCurrentView();
49
+ i0.ɵɵelementStart(0, "dr-button", 16);
50
+ i0.ɵɵlistener("click", function DrFileUploadComponent_div_2_ng_template_2_ng_template_8_Template_dr_button_click_0_listener($event) { i0.ɵɵrestoreView(_r15); const ctx_r14 = i0.ɵɵnextContext(3); ctx_r14.onBrowseClick(); return i0.ɵɵresetView($event.stopPropagation()); });
51
+ i0.ɵɵtext(1, " Browse ");
52
+ i0.ɵɵelementEnd();
53
+ } if (rf & 2) {
54
+ const ctx_r12 = i0.ɵɵnextContext(3);
55
+ i0.ɵɵattribute("aria-label", "Browse files. " + ctx_r12.acceptDescription);
56
+ } }
57
+ function DrFileUploadComponent_div_2_ng_template_2_Template(rf, ctx) { if (rf & 1) {
58
+ i0.ɵɵelementStart(0, "div", 9)(1, "div", 10)(2, "span", 11);
59
+ i0.ɵɵtext(3);
60
+ i0.ɵɵelementEnd();
61
+ i0.ɵɵtemplate(4, DrFileUploadComponent_div_2_ng_template_2_span_4_Template, 2, 1, "span", 12);
62
+ i0.ɵɵelementEnd();
63
+ i0.ɵɵelementStart(5, "span", 13);
64
+ i0.ɵɵtext(6, "Or");
65
+ i0.ɵɵelementEnd();
66
+ i0.ɵɵtemplate(7, DrFileUploadComponent_div_2_ng_template_2_ng_container_7_Template, 2, 1, "ng-container", 6);
67
+ i0.ɵɵtemplate(8, DrFileUploadComponent_div_2_ng_template_2_ng_template_8_Template, 2, 1, "ng-template", null, 14, i0.ɵɵtemplateRefExtractor);
68
+ i0.ɵɵelementEnd();
69
+ } if (rf & 2) {
70
+ const _r11 = i0.ɵɵreference(9);
71
+ const ctx_r7 = i0.ɵɵnextContext(2);
72
+ i0.ɵɵadvance(3);
73
+ i0.ɵɵtextInterpolate(ctx_r7.dropzoneText);
74
+ i0.ɵɵadvance(1);
75
+ i0.ɵɵproperty("ngIf", ctx_r7.computedDropzoneSubtext);
76
+ i0.ɵɵadvance(3);
77
+ i0.ɵɵproperty("ngIf", ctx_r7.browseButtonTemplate)("ngIfElse", _r11);
78
+ } }
79
+ function DrFileUploadComponent_div_2_Template(rf, ctx) { if (rf & 1) {
80
+ const _r17 = i0.ɵɵgetCurrentView();
81
+ i0.ɵɵelementStart(0, "div", 5);
82
+ i0.ɵɵlistener("fileDrop", function DrFileUploadComponent_div_2_Template_div_fileDrop_0_listener($event) { i0.ɵɵrestoreView(_r17); const ctx_r16 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r16.onFileDrop($event)); })("dragStateChange", function DrFileUploadComponent_div_2_Template_div_dragStateChange_0_listener($event) { i0.ɵɵrestoreView(_r17); const ctx_r18 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r18.onDragStateChange($event)); })("click", function DrFileUploadComponent_div_2_Template_div_click_0_listener() { i0.ɵɵrestoreView(_r17); const ctx_r19 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r19.onBrowseClick()); })("keydown.enter", function DrFileUploadComponent_div_2_Template_div_keydown_enter_0_listener() { i0.ɵɵrestoreView(_r17); const ctx_r20 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r20.onBrowseClick()); })("keydown.space", function DrFileUploadComponent_div_2_Template_div_keydown_space_0_listener($event) { i0.ɵɵrestoreView(_r17); const ctx_r21 = i0.ɵɵnextContext(); ctx_r21.onBrowseClick(); return i0.ɵɵresetView($event.preventDefault()); });
83
+ i0.ɵɵtemplate(1, DrFileUploadComponent_div_2_ng_container_1_Template, 2, 1, "ng-container", 6);
84
+ i0.ɵɵtemplate(2, DrFileUploadComponent_div_2_ng_template_2_Template, 10, 4, "ng-template", null, 7, i0.ɵɵtemplateRefExtractor);
85
+ i0.ɵɵelementEnd();
86
+ } if (rf & 2) {
87
+ const _r6 = i0.ɵɵreference(3);
88
+ const ctx_r1 = i0.ɵɵnextContext();
89
+ i0.ɵɵattribute("tabindex", ctx_r1.disabled ? -1 : 0)("aria-label", ctx_r1.dropzoneAriaLabel)("aria-disabled", ctx_r1.disabled)("aria-describedby", ctx_r1.validationErrorMessage ? "file-upload-error" : null);
90
+ i0.ɵɵadvance(1);
91
+ i0.ɵɵproperty("ngIf", ctx_r1.dropzoneTemplate)("ngIfElse", _r6);
92
+ } }
93
+ function DrFileUploadComponent_ng_container_3_ng_container_1_ng_container_1_Template(rf, ctx) { if (rf & 1) {
94
+ i0.ɵɵelementContainer(0);
95
+ } }
96
+ const _c5 = function (a0, a1) { return { $implicit: a0, remove: a1 }; };
97
+ function DrFileUploadComponent_ng_container_3_ng_container_1_Template(rf, ctx) { if (rf & 1) {
98
+ i0.ɵɵelementContainerStart(0);
99
+ i0.ɵɵtemplate(1, DrFileUploadComponent_ng_container_3_ng_container_1_ng_container_1_Template, 1, 0, "ng-container", 18);
100
+ i0.ɵɵelementContainerEnd();
101
+ } if (rf & 2) {
102
+ const ctx_r22 = i0.ɵɵnextContext(2);
103
+ i0.ɵɵadvance(1);
104
+ i0.ɵɵproperty("ngTemplateOutlet", ctx_r22.fileItemTemplate)("ngTemplateOutletContext", i0.ɵɵpureFunction2(2, _c5, ctx_r22.files[0], ctx_r22.onFileRemove.bind(ctx_r22)));
105
+ } }
106
+ function DrFileUploadComponent_ng_container_3_ng_template_2_Template(rf, ctx) { if (rf & 1) {
107
+ const _r27 = i0.ɵɵgetCurrentView();
108
+ i0.ɵɵelementStart(0, "div", 19)(1, "button", 20);
109
+ i0.ɵɵlistener("click", function DrFileUploadComponent_ng_container_3_ng_template_2_Template_button_click_1_listener() { i0.ɵɵrestoreView(_r27); const ctx_r26 = i0.ɵɵnextContext(2); return i0.ɵɵresetView(ctx_r26.onFileRemove(ctx_r26.files[0])); });
110
+ i0.ɵɵelement(2, "i", 21);
111
+ i0.ɵɵelementEnd();
112
+ i0.ɵɵelement(3, "dr-file-upload-item", 22);
113
+ i0.ɵɵelementEnd();
114
+ } if (rf & 2) {
115
+ const ctx_r24 = i0.ɵɵnextContext(2);
116
+ i0.ɵɵattribute("aria-label", "Uploaded file: " + ctx_r24.files[0].file.name);
117
+ i0.ɵɵadvance(1);
118
+ i0.ɵɵattribute("aria-label", "Remove file " + ctx_r24.files[0].file.name);
119
+ i0.ɵɵadvance(2);
120
+ i0.ɵɵproperty("item", ctx_r24.files[0])("removable", false);
121
+ } }
122
+ function DrFileUploadComponent_ng_container_3_Template(rf, ctx) { if (rf & 1) {
123
+ i0.ɵɵelementContainerStart(0);
124
+ i0.ɵɵtemplate(1, DrFileUploadComponent_ng_container_3_ng_container_1_Template, 2, 5, "ng-container", 6);
125
+ i0.ɵɵtemplate(2, DrFileUploadComponent_ng_container_3_ng_template_2_Template, 4, 4, "ng-template", null, 17, i0.ɵɵtemplateRefExtractor);
126
+ i0.ɵɵelementContainerEnd();
127
+ } if (rf & 2) {
128
+ const _r23 = i0.ɵɵreference(3);
129
+ const ctx_r2 = i0.ɵɵnextContext();
130
+ i0.ɵɵadvance(1);
131
+ i0.ɵɵproperty("ngIf", ctx_r2.fileItemTemplate)("ngIfElse", _r23);
132
+ } }
133
+ function DrFileUploadComponent_ng_container_4_li_5_ng_container_1_ng_container_1_Template(rf, ctx) { if (rf & 1) {
134
+ i0.ɵɵelementContainer(0);
135
+ } }
136
+ function DrFileUploadComponent_ng_container_4_li_5_ng_container_1_Template(rf, ctx) { if (rf & 1) {
137
+ i0.ɵɵelementContainerStart(0);
138
+ i0.ɵɵtemplate(1, DrFileUploadComponent_ng_container_4_li_5_ng_container_1_ng_container_1_Template, 1, 0, "ng-container", 18);
139
+ i0.ɵɵelementContainerEnd();
140
+ } if (rf & 2) {
141
+ const item_r30 = i0.ɵɵnextContext().$implicit;
142
+ const ctx_r31 = i0.ɵɵnextContext(2);
143
+ i0.ɵɵadvance(1);
144
+ i0.ɵɵproperty("ngTemplateOutlet", ctx_r31.fileItemTemplate)("ngTemplateOutletContext", i0.ɵɵpureFunction2(2, _c5, item_r30, ctx_r31.onFileRemove.bind(ctx_r31)));
145
+ } }
146
+ function DrFileUploadComponent_ng_container_4_li_5_ng_template_2_Template(rf, ctx) { if (rf & 1) {
147
+ const _r38 = i0.ɵɵgetCurrentView();
148
+ i0.ɵɵelementStart(0, "dr-file-upload-item", 30);
149
+ i0.ɵɵlistener("remove", function DrFileUploadComponent_ng_container_4_li_5_ng_template_2_Template_dr_file_upload_item_remove_0_listener() { i0.ɵɵrestoreView(_r38); const item_r30 = i0.ɵɵnextContext().$implicit; const ctx_r36 = i0.ɵɵnextContext(2); return i0.ɵɵresetView(ctx_r36.onFileRemove(item_r30)); });
150
+ i0.ɵɵelementEnd();
151
+ } if (rf & 2) {
152
+ const item_r30 = i0.ɵɵnextContext().$implicit;
153
+ i0.ɵɵproperty("item", item_r30)("removable", true)("compact", true);
154
+ } }
155
+ function DrFileUploadComponent_ng_container_4_li_5_Template(rf, ctx) { if (rf & 1) {
156
+ i0.ɵɵelementStart(0, "li", 28);
157
+ i0.ɵɵtemplate(1, DrFileUploadComponent_ng_container_4_li_5_ng_container_1_Template, 2, 5, "ng-container", 6);
158
+ i0.ɵɵtemplate(2, DrFileUploadComponent_ng_container_4_li_5_ng_template_2_Template, 1, 3, "ng-template", null, 29, i0.ɵɵtemplateRefExtractor);
159
+ i0.ɵɵelementEnd();
160
+ } if (rf & 2) {
161
+ const _r32 = i0.ɵɵreference(3);
162
+ const ctx_r28 = i0.ɵɵnextContext(2);
163
+ i0.ɵɵadvance(1);
164
+ i0.ɵɵproperty("ngIf", ctx_r28.fileItemTemplate)("ngIfElse", _r32);
165
+ } }
166
+ function DrFileUploadComponent_ng_container_4_div_6_Template(rf, ctx) { if (rf & 1) {
167
+ i0.ɵɵelementStart(0, "div", 31);
168
+ i0.ɵɵtext(1);
169
+ i0.ɵɵelementEnd();
170
+ } if (rf & 2) {
171
+ const ctx_r29 = i0.ɵɵnextContext(2);
172
+ i0.ɵɵadvance(1);
173
+ i0.ɵɵtextInterpolate2(" ", ctx_r29.failedFilesCount, " ", ctx_r29.failedFilesCount === 1 ? "file" : "files", " could not be uploaded. Please try again ");
174
+ } }
175
+ function DrFileUploadComponent_ng_container_4_Template(rf, ctx) { if (rf & 1) {
176
+ i0.ɵɵelementContainerStart(0);
177
+ i0.ɵɵelementStart(1, "div", 23)(2, "div", 24);
178
+ i0.ɵɵtext(3);
179
+ i0.ɵɵelementEnd();
180
+ i0.ɵɵelementStart(4, "ul", 25);
181
+ i0.ɵɵtemplate(5, DrFileUploadComponent_ng_container_4_li_5_Template, 4, 2, "li", 26);
182
+ i0.ɵɵelementEnd();
183
+ i0.ɵɵtemplate(6, DrFileUploadComponent_ng_container_4_div_6_Template, 2, 2, "div", 27);
184
+ i0.ɵɵelementEnd();
185
+ i0.ɵɵelementContainerEnd();
186
+ } if (rf & 2) {
187
+ const ctx_r3 = i0.ɵɵnextContext();
188
+ i0.ɵɵadvance(3);
189
+ i0.ɵɵtextInterpolate2(" ", ctx_r3.uploadedFiles.length, " ", ctx_r3.uploadedFiles.length === 1 ? "File" : "Files", " uploaded ");
190
+ i0.ɵɵadvance(1);
191
+ i0.ɵɵattribute("aria-label", ctx_r3.files.length + " files in upload queue");
192
+ i0.ɵɵadvance(1);
193
+ i0.ɵɵproperty("ngForOf", ctx_r3.files)("ngForTrackBy", ctx_r3.trackByFile);
194
+ i0.ɵɵadvance(1);
195
+ i0.ɵɵproperty("ngIf", ctx_r3.hasPartialSuccess);
196
+ } }
197
+ function DrFileUploadComponent_div_5_Template(rf, ctx) { if (rf & 1) {
198
+ i0.ɵɵelementStart(0, "div", 32);
199
+ i0.ɵɵtext(1);
200
+ i0.ɵɵelementEnd();
201
+ } if (rf & 2) {
202
+ const ctx_r4 = i0.ɵɵnextContext();
203
+ i0.ɵɵadvance(1);
204
+ i0.ɵɵtextInterpolate1(" ", ctx_r4.validationErrorMessage, "\n");
205
+ } }
206
+ export class DrFileUploadComponent {
207
+ constructor() {
208
+ this.cdr = inject(ChangeDetectorRef);
209
+ this.validationService = inject(FileUploadValidationService);
210
+ this.variant = 'single';
211
+ this.accept = '.xlsx,.xls';
212
+ this.maxFiles = 10;
213
+ this.disabled = false;
214
+ this.validateFormats = true;
215
+ this.dropzoneText = 'Drag & drop your .xlsx or .xls files here';
216
+ this.filesChange = new EventEmitter();
217
+ this.fileRemove = new EventEmitter();
218
+ this.validationError = new EventEmitter();
219
+ this._files = [];
220
+ this.isDragover = false;
221
+ }
222
+ set files(value) {
223
+ this._files = value;
224
+ }
225
+ get files() {
226
+ return this._files;
227
+ }
228
+ ngAfterViewInit() {
229
+ if (this.uploadTemplate) {
230
+ this.dropzoneTemplate = this.uploadTemplate.dropzoneTemplate;
231
+ this.fileItemTemplate = this.uploadTemplate.fileItemTemplate;
232
+ this.cdr.detectChanges();
233
+ }
234
+ }
235
+ get isDisabled() {
236
+ return this.disabled;
237
+ }
238
+ get hasDragover() {
239
+ return this.isDragover;
240
+ }
241
+ get hasFiles() {
242
+ return this.files.length > 0;
243
+ }
244
+ get isSingle() {
245
+ return this.variant === 'single';
246
+ }
247
+ get isMultiple() {
248
+ return this.variant === 'multiple';
249
+ }
250
+ get computedDropzoneSubtext() {
251
+ if (this.dropzoneSubtext) {
252
+ return this.dropzoneSubtext;
253
+ }
254
+ const hasMaxSize = this.maxFileSize !== undefined && this.maxFileSize !== Infinity && this.maxFileSize > 0;
255
+ const hasMaxFiles = this.maxFiles !== undefined && this.maxFiles !== Infinity && this.maxFiles > 0;
256
+ if (this.variant === 'multiple') {
257
+ const filesWord = this.maxFiles === 1 ? 'file' : 'files';
258
+ if (hasMaxFiles && hasMaxSize) {
259
+ return `(up to ${this.maxFiles} ${filesWord}, ${this.maxFileSize} MB each)`;
260
+ }
261
+ if (hasMaxFiles) {
262
+ return `(up to ${this.maxFiles} ${filesWord})`;
263
+ }
264
+ if (hasMaxSize) {
265
+ return `(up to ${this.maxFileSize} MB per file)`;
266
+ }
267
+ return '';
268
+ }
269
+ if (hasMaxSize) {
270
+ return `(up to ${this.maxFileSize} MB)`;
271
+ }
272
+ return '';
273
+ }
274
+ get validationErrorMessage() {
275
+ return this.invalidFormatError || this.invalidSizeError || this.overLimitError || this.errorMessage;
276
+ }
277
+ get showDropzone() {
278
+ if (this.variant === 'multiple') {
279
+ return true;
280
+ }
281
+ return this.files.length === 0;
282
+ }
283
+ get uploadedFiles() {
284
+ return this.files.filter((f) => f.status === 'success');
285
+ }
286
+ get failedFilesCount() {
287
+ return this.files.filter((f) => f.status === 'error').length;
288
+ }
289
+ get hasPartialSuccess() {
290
+ return this.uploadedFiles.length > 0 && this.failedFilesCount > 0;
291
+ }
292
+ get ariaLabel() {
293
+ if (this.customAriaLabel) {
294
+ return this.customAriaLabel;
295
+ }
296
+ const fileType = this.variant === 'single' ? 'file' : 'files';
297
+ return `Upload ${fileType}. ${this.acceptDescription}`;
298
+ }
299
+ get dropzoneAriaLabel() {
300
+ const action = this.variant === 'single' ? 'Click or drag and drop a file' : 'Click or drag and drop files';
301
+ return `${action}. ${this.acceptDescription}`;
302
+ }
303
+ get acceptDescription() {
304
+ const extensions = this.validationService.getAcceptedExtensions(this.accept);
305
+ if (extensions.length > 0) {
306
+ return `Accepted formats: ${extensions.map((e) => '.' + e).join(', ')}`;
307
+ }
308
+ const mimes = this.validationService.getAcceptedMimes(this.accept);
309
+ if (mimes.length > 0) {
310
+ return `Accepted types: ${mimes.join(', ')}`;
311
+ }
312
+ return 'All file types accepted';
313
+ }
314
+ trackByFile(_index, item) {
315
+ return item.file.name + item.file.size + item.file.lastModified;
316
+ }
317
+ onDragStateChange(isDragover) {
318
+ this.isDragover = isDragover;
319
+ this.cdr.markForCheck();
320
+ }
321
+ onFileDrop(fileList) {
322
+ this.handleFiles(fileList);
323
+ }
324
+ onBrowseClick() {
325
+ if (!this.disabled) {
326
+ this.fileInput?.nativeElement?.click();
327
+ }
328
+ }
329
+ onFileInputChange(event) {
330
+ const input = event.target;
331
+ if (input.files && input.files.length > 0) {
332
+ this.handleFiles(input.files);
333
+ input.value = '';
334
+ }
335
+ }
336
+ onFileRemove(item) {
337
+ this._files = this._files.filter((f) => f !== item);
338
+ this.fileRemove.emit(item.file);
339
+ this.filesChange.emit(this._files);
340
+ this.clearValidationErrors();
341
+ this.cdr.markForCheck();
342
+ }
343
+ handleFiles(fileList) {
344
+ if (this.disabled) {
345
+ return;
346
+ }
347
+ this.clearValidationErrors();
348
+ let filesArray = Array.from(fileList);
349
+ if (this.validateFormats) {
350
+ const result = this.validationService.filterByFormat(filesArray, this.accept);
351
+ filesArray = result.valid;
352
+ if (result.invalidFileName) {
353
+ this.invalidFormatError = `Invalid file format: ${result.invalidFileName}`;
354
+ this.validationError.emit({
355
+ type: 'format',
356
+ fileName: result.invalidFileName,
357
+ message: this.invalidFormatError,
358
+ });
359
+ }
360
+ }
361
+ if (this.maxFileSize !== undefined && this.maxFileSize !== Infinity && this.maxFileSize > 0) {
362
+ const result = this.validationService.filterBySize(filesArray, this.maxFileSize);
363
+ filesArray = result.valid;
364
+ if (result.oversizedFileName) {
365
+ this.invalidSizeError = `File too large: ${result.oversizedFileName} (max ${this.maxFileSize} MB)`;
366
+ this.validationError.emit({
367
+ type: 'size',
368
+ fileName: result.oversizedFileName,
369
+ message: this.invalidSizeError,
370
+ });
371
+ }
372
+ }
373
+ if (this.variant === 'multiple') {
374
+ const availableSlots = Math.max(this.maxFiles - this._files.length, 0);
375
+ if (availableSlots < filesArray.length) {
376
+ this.overLimitError = `Maximum ${this.maxFiles} files allowed`;
377
+ this.validationError.emit({
378
+ type: 'limit',
379
+ message: this.overLimitError,
380
+ });
381
+ filesArray = filesArray.slice(0, availableSlots);
382
+ }
383
+ }
384
+ if (filesArray.length === 0) {
385
+ this.cdr.markForCheck();
386
+ return;
387
+ }
388
+ const newItems = filesArray.map((file) => ({
389
+ file,
390
+ progress: 0,
391
+ status: 'pending',
392
+ }));
393
+ if (this.variant === 'single') {
394
+ this._files = newItems.slice(0, 1);
395
+ }
396
+ else {
397
+ this._files = [...this._files, ...newItems].slice(0, this.maxFiles);
398
+ }
399
+ this.filesChange.emit(this._files);
400
+ this.cdr.markForCheck();
401
+ }
402
+ clearValidationErrors() {
403
+ this.invalidFormatError = undefined;
404
+ this.invalidSizeError = undefined;
405
+ this.overLimitError = undefined;
406
+ }
407
+ /** @nocollapse */ static { this.ɵfac = function DrFileUploadComponent_Factory(t) { return new (t || DrFileUploadComponent)(); }; }
408
+ /** @nocollapse */ static { this.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: DrFileUploadComponent, selectors: [["dr-file-upload"]], contentQueries: function DrFileUploadComponent_ContentQueries(rf, ctx, dirIndex) { if (rf & 1) {
409
+ i0.ɵɵcontentQuery(dirIndex, _c0, 5);
410
+ i0.ɵɵcontentQuery(dirIndex, _c1, 5);
411
+ i0.ɵɵcontentQuery(dirIndex, _c2, 5);
412
+ i0.ɵɵcontentQuery(dirIndex, _c3, 5);
413
+ } if (rf & 2) {
414
+ let _t;
415
+ i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.dropzoneTemplate = _t.first);
416
+ i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.fileItemTemplate = _t.first);
417
+ i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.browseButtonTemplate = _t.first);
418
+ i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.uploadTemplate = _t.first);
419
+ } }, viewQuery: function DrFileUploadComponent_Query(rf, ctx) { if (rf & 1) {
420
+ i0.ɵɵviewQuery(_c4, 7);
421
+ } if (rf & 2) {
422
+ let _t;
423
+ i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.fileInput = _t.first);
424
+ } }, hostVars: 10, hostBindings: function DrFileUploadComponent_HostBindings(rf, ctx) { if (rf & 2) {
425
+ i0.ɵɵclassProp("dr-file-upload--disabled", ctx.isDisabled)("dr-file-upload--dragover", ctx.hasDragover)("dr-file-upload--has-files", ctx.hasFiles)("dr-file-upload--single", ctx.isSingle)("dr-file-upload--multiple", ctx.isMultiple);
426
+ } }, inputs: { variant: "variant", accept: "accept", maxFileSize: "maxFileSize", maxFiles: "maxFiles", disabled: ["disabled", "disabled", booleanAttribute], validateFormats: ["validateFormats", "validateFormats", booleanAttribute], dropzoneText: "dropzoneText", dropzoneSubtext: "dropzoneSubtext", errorMessage: "errorMessage", customAriaLabel: ["aria-label", "customAriaLabel"], files: "files" }, outputs: { filesChange: "filesChange", fileRemove: "fileRemove", validationError: "validationError" }, standalone: true, features: [i0.ɵɵInputTransformsFeature, i0.ɵɵStandaloneFeature], decls: 6, vars: 8, consts: [["type", "file", "hidden", "", 3, "accept", "multiple", "change"], ["fileInput", ""], ["class", "dr-file-upload__dropzone", "role", "button", "drDragDrop", "", 3, "fileDrop", "dragStateChange", "click", "keydown.enter", "keydown.space", 4, "ngIf"], [4, "ngIf"], ["id", "file-upload-error", "class", "dr-file-upload__error", "role", "alert", "aria-live", "assertive", 4, "ngIf"], ["role", "button", "drDragDrop", "", 1, "dr-file-upload__dropzone", 3, "fileDrop", "dragStateChange", "click", "keydown.enter", "keydown.space"], [4, "ngIf", "ngIfElse"], ["defaultDropzone", ""], [4, "ngTemplateOutlet"], [1, "dr-file-upload__dropzone-content"], [1, "dr-file-upload__dropzone-text"], [1, "dr-file-upload__dropzone-title"], ["class", "dr-file-upload__dropzone-subtitle", 4, "ngIf"], ["aria-hidden", "true", 1, "dr-file-upload__dropzone-or"], ["defaultBrowseButton", ""], [1, "dr-file-upload__dropzone-subtitle"], ["theme", "secondary", "icon", "dr-icon-add", 3, "click"], ["defaultSingleFileItem", ""], [4, "ngTemplateOutlet", "ngTemplateOutletContext"], ["role", "group", 1, "dr-file-upload__single-item-container"], ["type", "button", 1, "dr-file-upload__single-item-close", 3, "click"], ["aria-hidden", "true", 1, "dr-icon-exit"], [3, "item", "removable"], ["role", "region", "aria-label", "Uploaded files", 1, "dr-file-upload__files-section"], ["aria-live", "polite", 1, "dr-file-upload__files-header"], ["role", "list", 1, "dr-file-upload__files-list"], ["role", "listitem", 4, "ngFor", "ngForOf", "ngForTrackBy"], ["class", "dr-file-upload__partial-error", "role", "alert", "aria-live", "assertive", 4, "ngIf"], ["role", "listitem"], ["defaultMultipleFileItem", ""], [3, "item", "removable", "compact", "remove"], ["role", "alert", "aria-live", "assertive", 1, "dr-file-upload__partial-error"], ["id", "file-upload-error", "role", "alert", "aria-live", "assertive", 1, "dr-file-upload__error"]], template: function DrFileUploadComponent_Template(rf, ctx) { if (rf & 1) {
427
+ i0.ɵɵelementStart(0, "input", 0, 1);
428
+ i0.ɵɵlistener("change", function DrFileUploadComponent_Template_input_change_0_listener($event) { return ctx.onFileInputChange($event); });
429
+ i0.ɵɵelementEnd();
430
+ i0.ɵɵtemplate(2, DrFileUploadComponent_div_2_Template, 4, 6, "div", 2);
431
+ i0.ɵɵtemplate(3, DrFileUploadComponent_ng_container_3_Template, 4, 2, "ng-container", 3);
432
+ i0.ɵɵtemplate(4, DrFileUploadComponent_ng_container_4_Template, 7, 6, "ng-container", 3);
433
+ i0.ɵɵtemplate(5, DrFileUploadComponent_div_5_Template, 2, 1, "div", 4);
434
+ } if (rf & 2) {
435
+ i0.ɵɵproperty("accept", ctx.accept)("multiple", ctx.variant === "multiple");
436
+ i0.ɵɵattribute("aria-label", ctx.ariaLabel)("aria-describedby", ctx.validationErrorMessage ? "file-upload-error" : null);
437
+ i0.ɵɵadvance(2);
438
+ i0.ɵɵproperty("ngIf", ctx.showDropzone);
439
+ i0.ɵɵadvance(1);
440
+ i0.ɵɵproperty("ngIf", ctx.variant === "single" && ctx.files.length > 0);
441
+ i0.ɵɵadvance(1);
442
+ i0.ɵɵproperty("ngIf", ctx.variant === "multiple" && ctx.files.length > 0);
443
+ i0.ɵɵadvance(1);
444
+ i0.ɵɵproperty("ngIf", ctx.validationErrorMessage);
445
+ } }, dependencies: [CommonModule, i1.NgForOf, i1.NgIf, i1.NgTemplateOutlet, DrDragDropDirective, DrFileUploadItemComponent, DrButtonComponent], styles: ["[_nghost-%COMP%]{display:flex;flex-direction:column;gap:24px;width:100%}.dr-file-upload__dropzone[_ngcontent-%COMP%]{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:16px 32px;background:#fff;border:1px dashed #9ea1aa;border-radius:4px;cursor:pointer;transition:all .2s ease}.dr-file-upload__dropzone[_ngcontent-%COMP%]:hover{border-color:#4646ce;background-color:#f5f5f5}.dr-file-upload__dropzone[_ngcontent-%COMP%]:focus{outline:2px solid #4646ce;outline-offset:2px}.dr-file-upload__dropzone[_ngcontent-%COMP%]:focus:not(:focus-visible){outline:none}.dr-file-upload__dropzone[_ngcontent-%COMP%]:focus-visible{outline:2px solid #4646ce;outline-offset:2px;border-color:#4646ce}.dr-file-upload__dropzone-content[_ngcontent-%COMP%]{display:flex;flex-direction:column;align-items:center;gap:8px}.dr-file-upload__dropzone-text[_ngcontent-%COMP%]{display:flex;flex-direction:column;align-items:center;gap:4px}.dr-file-upload__dropzone-title[_ngcontent-%COMP%]{font-size:14px;line-height:24px;font-weight:400;color:#6d6e6f}.dr-file-upload__dropzone-subtitle[_ngcontent-%COMP%]{font-size:12px;line-height:16px;font-weight:400;color:#6d6e6f}.dr-file-upload__dropzone-or[_ngcontent-%COMP%]{font-size:14px;line-height:24px;font-weight:400;color:#6d6e6f}.dr-file-upload__files-section[_ngcontent-%COMP%]{display:flex;flex-direction:column;gap:8px}.dr-file-upload__files-header[_ngcontent-%COMP%]{font-size:14px;line-height:24px;font-weight:400;color:#333}.dr-file-upload__files-list[_ngcontent-%COMP%]{display:flex;flex-wrap:wrap;gap:10px;list-style:none;padding:0;margin:0}.dr-file-upload__files-list[_ngcontent-%COMP%] li[_ngcontent-%COMP%]{display:contents}.dr-file-upload__partial-error[_ngcontent-%COMP%], .dr-file-upload__error[_ngcontent-%COMP%]{font-size:12px;line-height:16px;font-weight:400;color:#bf1d30}.dr-file-upload__single-item-container[_ngcontent-%COMP%]{position:relative;padding:32px 16px;background:#fff;border:1px dashed #9ea1aa;border-radius:4px;min-height:126px;display:flex;align-items:center}.dr-file-upload__single-item-container[_ngcontent-%COMP%] dr-file-upload-item[_ngcontent-%COMP%]{border:none;padding:0;background:transparent}.dr-file-upload__single-item-close[_ngcontent-%COMP%]{display:flex;align-items:center;justify-content:center;position:absolute;top:4px;right:4px;padding:0;margin:0;border:none;background:transparent;cursor:pointer;z-index:1;border-radius:2px}.dr-file-upload__single-item-close[_ngcontent-%COMP%] i[_ngcontent-%COMP%]{font-size:16px;color:#333}.dr-file-upload__single-item-close[_ngcontent-%COMP%]:hover i[_ngcontent-%COMP%]{color:#333}.dr-file-upload__single-item-close[_ngcontent-%COMP%]:focus{outline:2px solid #4646ce;outline-offset:2px}.dr-file-upload__single-item-close[_ngcontent-%COMP%]:focus:not(:focus-visible){outline:none}.dr-file-upload__single-item-close[_ngcontent-%COMP%]:focus-visible{outline:2px solid #4646ce;outline-offset:2px}.dr-file-upload--dragover[_nghost-%COMP%] .dr-file-upload__dropzone[_ngcontent-%COMP%]{background:#f5f5f5;border-color:#4646ce}.dr-file-upload--disabled[_nghost-%COMP%] .dr-file-upload__dropzone[_ngcontent-%COMP%]{pointer-events:none;opacity:.6}.dr-file-upload--disabled[_nghost-%COMP%] .dr-file-upload__dropzone[_ngcontent-%COMP%]:hover{border-color:#9ea1aa}.dr-file-upload--single[_nghost-%COMP%] .dr-file-upload__dropzone[_ngcontent-%COMP%]{min-height:148px}.dr-file-upload--multiple[_nghost-%COMP%] .dr-file-upload__dropzone[_ngcontent-%COMP%]{min-height:100px}"], changeDetection: 0 }); }
446
+ }
447
+ (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(DrFileUploadComponent, [{
448
+ type: Component,
449
+ args: [{ selector: 'dr-file-upload', standalone: true, imports: [CommonModule, DrDragDropDirective, DrFileUploadItemComponent, DrButtonComponent], changeDetection: ChangeDetectionStrategy.OnPush, template: "<input\n #fileInput\n type=\"file\"\n [accept]=\"accept\"\n [multiple]=\"variant === 'multiple'\"\n [attr.aria-label]=\"ariaLabel\"\n [attr.aria-describedby]=\"validationErrorMessage ? 'file-upload-error' : null\"\n (change)=\"onFileInputChange($event)\"\n hidden />\n\n<div\n *ngIf=\"showDropzone\"\n class=\"dr-file-upload__dropzone\"\n role=\"button\"\n [attr.tabindex]=\"disabled ? -1 : 0\"\n [attr.aria-label]=\"dropzoneAriaLabel\"\n [attr.aria-disabled]=\"disabled\"\n [attr.aria-describedby]=\"validationErrorMessage ? 'file-upload-error' : null\"\n drDragDrop\n (fileDrop)=\"onFileDrop($event)\"\n (dragStateChange)=\"onDragStateChange($event)\"\n (click)=\"onBrowseClick()\"\n (keydown.enter)=\"onBrowseClick()\"\n (keydown.space)=\"onBrowseClick(); $event.preventDefault()\">\n <ng-container *ngIf=\"dropzoneTemplate; else defaultDropzone\">\n <ng-container *ngTemplateOutlet=\"dropzoneTemplate\"></ng-container>\n </ng-container>\n\n <ng-template #defaultDropzone>\n <div class=\"dr-file-upload__dropzone-content\">\n <div class=\"dr-file-upload__dropzone-text\">\n <span class=\"dr-file-upload__dropzone-title\">{{ dropzoneText }}</span>\n <span *ngIf=\"computedDropzoneSubtext\" class=\"dr-file-upload__dropzone-subtitle\">{{\n computedDropzoneSubtext\n }}</span>\n </div>\n <span class=\"dr-file-upload__dropzone-or\" aria-hidden=\"true\">Or</span>\n <ng-container *ngIf=\"browseButtonTemplate; else defaultBrowseButton\">\n <ng-container *ngTemplateOutlet=\"browseButtonTemplate\"></ng-container>\n </ng-container>\n <ng-template #defaultBrowseButton>\n <dr-button\n theme=\"secondary\"\n icon=\"dr-icon-add\"\n [attr.aria-label]=\"'Browse files. ' + acceptDescription\"\n (click)=\"onBrowseClick(); $event.stopPropagation()\">\n Browse\n </dr-button>\n </ng-template>\n </div>\n </ng-template>\n</div>\n\n<ng-container *ngIf=\"variant === 'single' && files.length > 0\">\n <ng-container *ngIf=\"fileItemTemplate; else defaultSingleFileItem\">\n <ng-container *ngTemplateOutlet=\"fileItemTemplate; context: { $implicit: files[0], remove: onFileRemove.bind(this) }\">\n </ng-container>\n </ng-container>\n\n <ng-template #defaultSingleFileItem>\n <div\n class=\"dr-file-upload__single-item-container\"\n role=\"group\"\n [attr.aria-label]=\"'Uploaded file: ' + files[0].file.name\">\n <button\n type=\"button\"\n class=\"dr-file-upload__single-item-close\"\n [attr.aria-label]=\"'Remove file ' + files[0].file.name\"\n (click)=\"onFileRemove(files[0])\">\n <i class=\"dr-icon-exit\" aria-hidden=\"true\"></i>\n </button>\n <dr-file-upload-item [item]=\"files[0]\" [removable]=\"false\"> </dr-file-upload-item>\n </div>\n </ng-template>\n</ng-container>\n\n<ng-container *ngIf=\"variant === 'multiple' && files.length > 0\">\n <div class=\"dr-file-upload__files-section\" role=\"region\" aria-label=\"Uploaded files\">\n <div class=\"dr-file-upload__files-header\" aria-live=\"polite\">\n {{ uploadedFiles.length }} {{ uploadedFiles.length === 1 ? 'File' : 'Files' }} uploaded\n </div>\n <ul class=\"dr-file-upload__files-list\" role=\"list\" [attr.aria-label]=\"files.length + ' files in upload queue'\">\n <li *ngFor=\"let item of files; trackBy: trackByFile\" role=\"listitem\">\n <ng-container *ngIf=\"fileItemTemplate; else defaultMultipleFileItem\">\n <ng-container\n *ngTemplateOutlet=\"fileItemTemplate; context: { $implicit: item, remove: onFileRemove.bind(this) }\">\n </ng-container>\n </ng-container>\n\n <ng-template #defaultMultipleFileItem>\n <dr-file-upload-item [item]=\"item\" [removable]=\"true\" [compact]=\"true\" (remove)=\"onFileRemove(item)\">\n </dr-file-upload-item>\n </ng-template>\n </li>\n </ul>\n <div *ngIf=\"hasPartialSuccess\" class=\"dr-file-upload__partial-error\" role=\"alert\" aria-live=\"assertive\">\n {{ failedFilesCount }} {{ failedFilesCount === 1 ? 'file' : 'files' }} could not be uploaded. Please try again\n </div>\n </div>\n</ng-container>\n\n<div\n *ngIf=\"validationErrorMessage\"\n id=\"file-upload-error\"\n class=\"dr-file-upload__error\"\n role=\"alert\"\n aria-live=\"assertive\">\n {{ validationErrorMessage }}\n</div>\n", styles: [":host{display:flex;flex-direction:column;gap:24px;width:100%}.dr-file-upload__dropzone{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:16px 32px;background:#fff;border:1px dashed #9ea1aa;border-radius:4px;cursor:pointer;transition:all .2s ease}.dr-file-upload__dropzone:hover{border-color:#4646ce;background-color:#f5f5f5}.dr-file-upload__dropzone:focus{outline:2px solid #4646ce;outline-offset:2px}.dr-file-upload__dropzone:focus:not(:focus-visible){outline:none}.dr-file-upload__dropzone:focus-visible{outline:2px solid #4646ce;outline-offset:2px;border-color:#4646ce}.dr-file-upload__dropzone-content{display:flex;flex-direction:column;align-items:center;gap:8px}.dr-file-upload__dropzone-text{display:flex;flex-direction:column;align-items:center;gap:4px}.dr-file-upload__dropzone-title{font-size:14px;line-height:24px;font-weight:400;color:#6d6e6f}.dr-file-upload__dropzone-subtitle{font-size:12px;line-height:16px;font-weight:400;color:#6d6e6f}.dr-file-upload__dropzone-or{font-size:14px;line-height:24px;font-weight:400;color:#6d6e6f}.dr-file-upload__files-section{display:flex;flex-direction:column;gap:8px}.dr-file-upload__files-header{font-size:14px;line-height:24px;font-weight:400;color:#333}.dr-file-upload__files-list{display:flex;flex-wrap:wrap;gap:10px;list-style:none;padding:0;margin:0}.dr-file-upload__files-list li{display:contents}.dr-file-upload__partial-error,.dr-file-upload__error{font-size:12px;line-height:16px;font-weight:400;color:#bf1d30}.dr-file-upload__single-item-container{position:relative;padding:32px 16px;background:#fff;border:1px dashed #9ea1aa;border-radius:4px;min-height:126px;display:flex;align-items:center}.dr-file-upload__single-item-container dr-file-upload-item{border:none;padding:0;background:transparent}.dr-file-upload__single-item-close{display:flex;align-items:center;justify-content:center;position:absolute;top:4px;right:4px;padding:0;margin:0;border:none;background:transparent;cursor:pointer;z-index:1;border-radius:2px}.dr-file-upload__single-item-close i{font-size:16px;color:#333}.dr-file-upload__single-item-close:hover i{color:#333}.dr-file-upload__single-item-close:focus{outline:2px solid #4646ce;outline-offset:2px}.dr-file-upload__single-item-close:focus:not(:focus-visible){outline:none}.dr-file-upload__single-item-close:focus-visible{outline:2px solid #4646ce;outline-offset:2px}:host(.dr-file-upload--dragover) .dr-file-upload__dropzone{background:#f5f5f5;border-color:#4646ce}:host(.dr-file-upload--disabled) .dr-file-upload__dropzone{pointer-events:none;opacity:.6}:host(.dr-file-upload--disabled) .dr-file-upload__dropzone:hover{border-color:#9ea1aa}:host(.dr-file-upload--single) .dr-file-upload__dropzone{min-height:148px}:host(.dr-file-upload--multiple) .dr-file-upload__dropzone{min-height:100px}\n"] }]
450
+ }], null, { variant: [{
451
+ type: Input
452
+ }], accept: [{
453
+ type: Input
454
+ }], maxFileSize: [{
455
+ type: Input
456
+ }], maxFiles: [{
457
+ type: Input
458
+ }], disabled: [{
459
+ type: Input,
460
+ args: [{ transform: booleanAttribute }]
461
+ }], validateFormats: [{
462
+ type: Input,
463
+ args: [{ transform: booleanAttribute }]
464
+ }], dropzoneText: [{
465
+ type: Input
466
+ }], dropzoneSubtext: [{
467
+ type: Input
468
+ }], errorMessage: [{
469
+ type: Input
470
+ }], customAriaLabel: [{
471
+ type: Input,
472
+ args: ['aria-label']
473
+ }], files: [{
474
+ type: Input
475
+ }], filesChange: [{
476
+ type: Output
477
+ }], fileRemove: [{
478
+ type: Output
479
+ }], validationError: [{
480
+ type: Output
481
+ }], dropzoneTemplate: [{
482
+ type: ContentChild,
483
+ args: ['dropzoneTemplate']
484
+ }], fileItemTemplate: [{
485
+ type: ContentChild,
486
+ args: ['fileItemTemplate']
487
+ }], browseButtonTemplate: [{
488
+ type: ContentChild,
489
+ args: ['browseButtonTemplate']
490
+ }], uploadTemplate: [{
491
+ type: ContentChild,
492
+ args: ['uploadTemplate']
493
+ }], fileInput: [{
494
+ type: ViewChild,
495
+ args: ['fileInput', { static: true }]
496
+ }], isDisabled: [{
497
+ type: HostBinding,
498
+ args: ['class.dr-file-upload--disabled']
499
+ }], hasDragover: [{
500
+ type: HostBinding,
501
+ args: ['class.dr-file-upload--dragover']
502
+ }], hasFiles: [{
503
+ type: HostBinding,
504
+ args: ['class.dr-file-upload--has-files']
505
+ }], isSingle: [{
506
+ type: HostBinding,
507
+ args: ['class.dr-file-upload--single']
508
+ }], isMultiple: [{
509
+ type: HostBinding,
510
+ args: ['class.dr-file-upload--multiple']
511
+ }] }); })();
512
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-file-upload.component.js","sourceRoot":"","sources":["../../../../../projects/datarailsshared/src/lib/dr-file-upload/dr-file-upload.component.ts","../../../../../projects/datarailsshared/src/lib/dr-file-upload/dr-file-upload.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    booleanAttribute,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ContentChild,\n    ElementRef,\n    EventEmitter,\n    HostBinding,\n    inject,\n    Input,\n    Output,\n    TemplateRef,\n    ViewChild,\n} from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { FileUploadVariant, FileUploadItem, FileUploadTemplate } from './models/file-upload.models';\nimport { DrDragDropDirective } from './directives/drag-drop.directive';\nimport { DrFileUploadItemComponent } from './dr-file-upload-item/dr-file-upload-item.component';\nimport { DrButtonComponent } from '../dr-inputs/button/button.component';\nimport { FileUploadValidationService } from './services/file-upload-validation.service';\n\n@Component({\n    selector: 'dr-file-upload',\n    standalone: true,\n    imports: [CommonModule, DrDragDropDirective, DrFileUploadItemComponent, DrButtonComponent],\n    templateUrl: './dr-file-upload.component.html',\n    styleUrls: ['./dr-file-upload.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class DrFileUploadComponent implements AfterViewInit {\n    private readonly cdr = inject(ChangeDetectorRef);\n    private readonly validationService = inject(FileUploadValidationService);\n\n    @Input()\n    variant: FileUploadVariant = 'single';\n    @Input()\n    accept = '.xlsx,.xls';\n    /**\n     * Specifies the maximum allowed file size for uploads, in megabytes (MB).\n     */\n    @Input()\n    maxFileSize?: number;\n    @Input()\n    maxFiles = 10;\n    @Input({ transform: booleanAttribute })\n    disabled = false;\n    @Input({ transform: booleanAttribute })\n    validateFormats = true;\n\n    @Input()\n    dropzoneText = 'Drag & drop your .xlsx or .xls files here';\n    @Input()\n    dropzoneSubtext?: string;\n    @Input()\n    errorMessage?: string;\n    @Input('aria-label')\n    customAriaLabel?: string;\n    @Input()\n    set files(value: FileUploadItem[]) {\n        this._files = value;\n    }\n    get files(): FileUploadItem[] {\n        return this._files;\n    }\n\n    @Output()\n    readonly filesChange = new EventEmitter<FileUploadItem[]>();\n    @Output()\n    readonly fileRemove = new EventEmitter<File>();\n    @Output()\n    readonly validationError = new EventEmitter<{ type: 'format' | 'size' | 'limit'; fileName?: string; message: string }>();\n\n    private _files: FileUploadItem[] = [];\n    invalidFormatError?: string;\n    invalidSizeError?: string;\n    overLimitError?: string;\n\n    @ContentChild('dropzoneTemplate')\n    dropzoneTemplate?: TemplateRef<unknown>;\n    @ContentChild('fileItemTemplate')\n    fileItemTemplate?: TemplateRef<unknown>;\n    @ContentChild('browseButtonTemplate')\n    browseButtonTemplate?: TemplateRef<unknown>;\n    @ContentChild('uploadTemplate')\n    uploadTemplate?: FileUploadTemplate;\n\n    @ViewChild('fileInput', { static: true })\n    fileInput!: ElementRef<HTMLInputElement>;\n\n    isDragover = false;\n\n    ngAfterViewInit(): void {\n        if (this.uploadTemplate) {\n            this.dropzoneTemplate = this.uploadTemplate.dropzoneTemplate;\n            this.fileItemTemplate = this.uploadTemplate.fileItemTemplate;\n            this.cdr.detectChanges();\n        }\n    }\n\n    @HostBinding('class.dr-file-upload--disabled')\n    get isDisabled(): boolean {\n        return this.disabled;\n    }\n\n    @HostBinding('class.dr-file-upload--dragover')\n    get hasDragover(): boolean {\n        return this.isDragover;\n    }\n\n    @HostBinding('class.dr-file-upload--has-files')\n    get hasFiles(): boolean {\n        return this.files.length > 0;\n    }\n\n    @HostBinding('class.dr-file-upload--single')\n    get isSingle(): boolean {\n        return this.variant === 'single';\n    }\n\n    @HostBinding('class.dr-file-upload--multiple')\n    get isMultiple(): boolean {\n        return this.variant === 'multiple';\n    }\n\n    get computedDropzoneSubtext(): string {\n        if (this.dropzoneSubtext) {\n            return this.dropzoneSubtext;\n        }\n        const hasMaxSize = this.maxFileSize !== undefined && this.maxFileSize !== Infinity && this.maxFileSize > 0;\n        const hasMaxFiles = this.maxFiles !== undefined && this.maxFiles !== Infinity && this.maxFiles > 0;\n\n        if (this.variant === 'multiple') {\n            const filesWord = this.maxFiles === 1 ? 'file' : 'files';\n            if (hasMaxFiles && hasMaxSize) {\n                return `(up to ${this.maxFiles} ${filesWord}, ${this.maxFileSize} MB each)`;\n            }\n            if (hasMaxFiles) {\n                return `(up to ${this.maxFiles} ${filesWord})`;\n            }\n            if (hasMaxSize) {\n                return `(up to ${this.maxFileSize} MB per file)`;\n            }\n            return '';\n        }\n        if (hasMaxSize) {\n            return `(up to ${this.maxFileSize} MB)`;\n        }\n        return '';\n    }\n\n    get validationErrorMessage(): string | undefined {\n        return this.invalidFormatError || this.invalidSizeError || this.overLimitError || this.errorMessage;\n    }\n\n    get showDropzone(): boolean {\n        if (this.variant === 'multiple') {\n            return true;\n        }\n        return this.files.length === 0;\n    }\n\n    get uploadedFiles(): FileUploadItem[] {\n        return this.files.filter((f) => f.status === 'success');\n    }\n\n    get failedFilesCount(): number {\n        return this.files.filter((f) => f.status === 'error').length;\n    }\n\n    get hasPartialSuccess(): boolean {\n        return this.uploadedFiles.length > 0 && this.failedFilesCount > 0;\n    }\n\n    get ariaLabel(): string {\n        if (this.customAriaLabel) {\n            return this.customAriaLabel;\n        }\n        const fileType = this.variant === 'single' ? 'file' : 'files';\n        return `Upload ${fileType}. ${this.acceptDescription}`;\n    }\n\n    get dropzoneAriaLabel(): string {\n        const action = this.variant === 'single' ? 'Click or drag and drop a file' : 'Click or drag and drop files';\n        return `${action}. ${this.acceptDescription}`;\n    }\n\n    get acceptDescription(): string {\n        const extensions = this.validationService.getAcceptedExtensions(this.accept);\n        if (extensions.length > 0) {\n            return `Accepted formats: ${extensions.map((e) => '.' + e).join(', ')}`;\n        }\n        const mimes = this.validationService.getAcceptedMimes(this.accept);\n        if (mimes.length > 0) {\n            return `Accepted types: ${mimes.join(', ')}`;\n        }\n        return 'All file types accepted';\n    }\n\n    trackByFile(_index: number, item: FileUploadItem): string {\n        return item.file.name + item.file.size + item.file.lastModified;\n    }\n\n    onDragStateChange(isDragover: boolean): void {\n        this.isDragover = isDragover;\n        this.cdr.markForCheck();\n    }\n\n    onFileDrop(fileList: FileList): void {\n        this.handleFiles(fileList);\n    }\n\n    onBrowseClick(): void {\n        if (!this.disabled) {\n            this.fileInput?.nativeElement?.click();\n        }\n    }\n\n    onFileInputChange(event: Event): void {\n        const input = event.target as HTMLInputElement;\n        if (input.files && input.files.length > 0) {\n            this.handleFiles(input.files);\n            input.value = '';\n        }\n    }\n\n    onFileRemove(item: FileUploadItem): void {\n        this._files = this._files.filter((f) => f !== item);\n        this.fileRemove.emit(item.file);\n        this.filesChange.emit(this._files);\n        this.clearValidationErrors();\n        this.cdr.markForCheck();\n    }\n\n    private handleFiles(fileList: FileList): void {\n        if (this.disabled) {\n            return;\n        }\n\n        this.clearValidationErrors();\n\n        let filesArray = Array.from(fileList);\n\n        if (this.validateFormats) {\n            const result = this.validationService.filterByFormat(filesArray, this.accept);\n            filesArray = result.valid;\n            if (result.invalidFileName) {\n                this.invalidFormatError = `Invalid file format: ${result.invalidFileName}`;\n                this.validationError.emit({\n                    type: 'format',\n                    fileName: result.invalidFileName,\n                    message: this.invalidFormatError,\n                });\n            }\n        }\n\n        if (this.maxFileSize !== undefined && this.maxFileSize !== Infinity && this.maxFileSize > 0) {\n            const result = this.validationService.filterBySize(filesArray, this.maxFileSize);\n            filesArray = result.valid;\n            if (result.oversizedFileName) {\n                this.invalidSizeError = `File too large: ${result.oversizedFileName} (max ${this.maxFileSize} MB)`;\n                this.validationError.emit({\n                    type: 'size',\n                    fileName: result.oversizedFileName,\n                    message: this.invalidSizeError,\n                });\n            }\n        }\n\n        if (this.variant === 'multiple') {\n            const availableSlots = Math.max(this.maxFiles - this._files.length, 0);\n            if (availableSlots < filesArray.length) {\n                this.overLimitError = `Maximum ${this.maxFiles} files allowed`;\n                this.validationError.emit({\n                    type: 'limit',\n                    message: this.overLimitError,\n                });\n                filesArray = filesArray.slice(0, availableSlots);\n            }\n        }\n\n        if (filesArray.length === 0) {\n            this.cdr.markForCheck();\n            return;\n        }\n\n        const newItems: FileUploadItem[] = filesArray.map((file) => ({\n            file,\n            progress: 0,\n            status: 'pending' as const,\n        }));\n\n        if (this.variant === 'single') {\n            this._files = newItems.slice(0, 1);\n        } else {\n            this._files = [...this._files, ...newItems].slice(0, this.maxFiles);\n        }\n\n        this.filesChange.emit(this._files);\n        this.cdr.markForCheck();\n    }\n\n    private clearValidationErrors(): void {\n        this.invalidFormatError = undefined;\n        this.invalidSizeError = undefined;\n        this.overLimitError = undefined;\n    }\n}\n","<input\n    #fileInput\n    type=\"file\"\n    [accept]=\"accept\"\n    [multiple]=\"variant === 'multiple'\"\n    [attr.aria-label]=\"ariaLabel\"\n    [attr.aria-describedby]=\"validationErrorMessage ? 'file-upload-error' : null\"\n    (change)=\"onFileInputChange($event)\"\n    hidden />\n\n<div\n    *ngIf=\"showDropzone\"\n    class=\"dr-file-upload__dropzone\"\n    role=\"button\"\n    [attr.tabindex]=\"disabled ? -1 : 0\"\n    [attr.aria-label]=\"dropzoneAriaLabel\"\n    [attr.aria-disabled]=\"disabled\"\n    [attr.aria-describedby]=\"validationErrorMessage ? 'file-upload-error' : null\"\n    drDragDrop\n    (fileDrop)=\"onFileDrop($event)\"\n    (dragStateChange)=\"onDragStateChange($event)\"\n    (click)=\"onBrowseClick()\"\n    (keydown.enter)=\"onBrowseClick()\"\n    (keydown.space)=\"onBrowseClick(); $event.preventDefault()\">\n    <ng-container *ngIf=\"dropzoneTemplate; else defaultDropzone\">\n        <ng-container *ngTemplateOutlet=\"dropzoneTemplate\"></ng-container>\n    </ng-container>\n\n    <ng-template #defaultDropzone>\n        <div class=\"dr-file-upload__dropzone-content\">\n            <div class=\"dr-file-upload__dropzone-text\">\n                <span class=\"dr-file-upload__dropzone-title\">{{ dropzoneText }}</span>\n                <span *ngIf=\"computedDropzoneSubtext\" class=\"dr-file-upload__dropzone-subtitle\">{{\n                    computedDropzoneSubtext\n                }}</span>\n            </div>\n            <span class=\"dr-file-upload__dropzone-or\" aria-hidden=\"true\">Or</span>\n            <ng-container *ngIf=\"browseButtonTemplate; else defaultBrowseButton\">\n                <ng-container *ngTemplateOutlet=\"browseButtonTemplate\"></ng-container>\n            </ng-container>\n            <ng-template #defaultBrowseButton>\n                <dr-button\n                    theme=\"secondary\"\n                    icon=\"dr-icon-add\"\n                    [attr.aria-label]=\"'Browse files. ' + acceptDescription\"\n                    (click)=\"onBrowseClick(); $event.stopPropagation()\">\n                    Browse\n                </dr-button>\n            </ng-template>\n        </div>\n    </ng-template>\n</div>\n\n<ng-container *ngIf=\"variant === 'single' && files.length > 0\">\n    <ng-container *ngIf=\"fileItemTemplate; else defaultSingleFileItem\">\n        <ng-container *ngTemplateOutlet=\"fileItemTemplate; context: { $implicit: files[0], remove: onFileRemove.bind(this) }\">\n        </ng-container>\n    </ng-container>\n\n    <ng-template #defaultSingleFileItem>\n        <div\n            class=\"dr-file-upload__single-item-container\"\n            role=\"group\"\n            [attr.aria-label]=\"'Uploaded file: ' + files[0].file.name\">\n            <button\n                type=\"button\"\n                class=\"dr-file-upload__single-item-close\"\n                [attr.aria-label]=\"'Remove file ' + files[0].file.name\"\n                (click)=\"onFileRemove(files[0])\">\n                <i class=\"dr-icon-exit\" aria-hidden=\"true\"></i>\n            </button>\n            <dr-file-upload-item [item]=\"files[0]\" [removable]=\"false\"> </dr-file-upload-item>\n        </div>\n    </ng-template>\n</ng-container>\n\n<ng-container *ngIf=\"variant === 'multiple' && files.length > 0\">\n    <div class=\"dr-file-upload__files-section\" role=\"region\" aria-label=\"Uploaded files\">\n        <div class=\"dr-file-upload__files-header\" aria-live=\"polite\">\n            {{ uploadedFiles.length }} {{ uploadedFiles.length === 1 ? 'File' : 'Files' }} uploaded\n        </div>\n        <ul class=\"dr-file-upload__files-list\" role=\"list\" [attr.aria-label]=\"files.length + ' files in upload queue'\">\n            <li *ngFor=\"let item of files; trackBy: trackByFile\" role=\"listitem\">\n                <ng-container *ngIf=\"fileItemTemplate; else defaultMultipleFileItem\">\n                    <ng-container\n                        *ngTemplateOutlet=\"fileItemTemplate; context: { $implicit: item, remove: onFileRemove.bind(this) }\">\n                    </ng-container>\n                </ng-container>\n\n                <ng-template #defaultMultipleFileItem>\n                    <dr-file-upload-item [item]=\"item\" [removable]=\"true\" [compact]=\"true\" (remove)=\"onFileRemove(item)\">\n                    </dr-file-upload-item>\n                </ng-template>\n            </li>\n        </ul>\n        <div *ngIf=\"hasPartialSuccess\" class=\"dr-file-upload__partial-error\" role=\"alert\" aria-live=\"assertive\">\n            {{ failedFilesCount }} {{ failedFilesCount === 1 ? 'file' : 'files' }} could not be uploaded. Please try again\n        </div>\n    </div>\n</ng-container>\n\n<div\n    *ngIf=\"validationErrorMessage\"\n    id=\"file-upload-error\"\n    class=\"dr-file-upload__error\"\n    role=\"alert\"\n    aria-live=\"assertive\">\n    {{ validationErrorMessage }}\n</div>\n"]}
@@ -0,0 +1,6 @@
1
+ export * from './dr-file-upload.component';
2
+ export * from './dr-file-upload-item/dr-file-upload-item.component';
3
+ export * from './models/file-upload.models';
4
+ export * from './templates/dr-file-upload-image-template/dr-file-upload-image-template.component';
5
+ export * from './services/file-upload-validation.service';
6
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kYXRhcmFpbHNzaGFyZWQvc3JjL2xpYi9kci1maWxlLXVwbG9hZC9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLDRCQUE0QixDQUFDO0FBQzNDLGNBQWMscURBQXFELENBQUM7QUFDcEUsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLG1GQUFtRixDQUFDO0FBQ2xHLGNBQWMsMkNBQTJDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2RyLWZpbGUtdXBsb2FkLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2RyLWZpbGUtdXBsb2FkLWl0ZW0vZHItZmlsZS11cGxvYWQtaXRlbS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9tb2RlbHMvZmlsZS11cGxvYWQubW9kZWxzJztcbmV4cG9ydCAqIGZyb20gJy4vdGVtcGxhdGVzL2RyLWZpbGUtdXBsb2FkLWltYWdlLXRlbXBsYXRlL2RyLWZpbGUtdXBsb2FkLWltYWdlLXRlbXBsYXRlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3NlcnZpY2VzL2ZpbGUtdXBsb2FkLXZhbGlkYXRpb24uc2VydmljZSc7XG4iXX0=
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS11cGxvYWQubW9kZWxzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZGF0YXJhaWxzc2hhcmVkL3NyYy9saWIvZHItZmlsZS11cGxvYWQvbW9kZWxzL2ZpbGUtdXBsb2FkLm1vZGVscy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVGVtcGxhdGVSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuZXhwb3J0IHR5cGUgRmlsZVVwbG9hZFZhcmlhbnQgPSAnc2luZ2xlJyB8ICdtdWx0aXBsZSc7XG5cbmV4cG9ydCB0eXBlIEZpbGVVcGxvYWRJdGVtU3RhdHVzID0gJ2lkbGUnIHwgJ3BlbmRpbmcnIHwgJ3VwbG9hZGluZycgfCAnc3VjY2VzcycgfCAnZXJyb3InO1xuXG5leHBvcnQgaW50ZXJmYWNlIEZpbGVVcGxvYWRJdGVtIHtcbiAgICBmaWxlOiBGaWxlO1xuICAgIHByb2dyZXNzOiBudW1iZXI7XG4gICAgc3RhdHVzOiBGaWxlVXBsb2FkSXRlbVN0YXR1cztcbiAgICBlcnJvck1lc3NhZ2U/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRmlsZVVwbG9hZFRlbXBsYXRlIHtcbiAgICBkcm9wem9uZVRlbXBsYXRlPzogVGVtcGxhdGVSZWY8dW5rbm93bj47XG4gICAgZmlsZUl0ZW1UZW1wbGF0ZT86IFRlbXBsYXRlUmVmPHVua25vd24+O1xufVxuIl19