@uiapplibct/ngx-reusa-app-lib 0.0.1 → 0.0.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -1
- package/esm2022/lib/components/file-uploader/file-uploader.component.mjs +93 -15
- package/esm2022/lib/components/header/header.component.mjs +2 -2
- package/esm2022/lib/interceptors/error-interceptor/http-error-interceptor.mjs +3 -1
- package/esm2022/lib/services/audit/audit.service.mjs +35 -0
- package/esm2022/lib/services/dms-service/dms.service.mjs +7 -1
- package/fesm2022/uiapplibct-ngx-reusa-app-lib.mjs +211 -96
- package/fesm2022/uiapplibct-ngx-reusa-app-lib.mjs.map +1 -1
- package/lib/components/file-uploader/file-uploader.component.d.ts +10 -2
- package/lib/components/file-uploader/file-uploader.component.d.ts.map +1 -1
- package/lib/interceptors/error-interceptor/http-error-interceptor.d.ts.map +1 -1
- package/lib/services/audit/audit.service.d.ts +16 -0
- package/lib/services/audit/audit.service.d.ts.map +1 -0
- package/lib/services/dms-service/dms.service.d.ts +2 -0
- package/lib/services/dms-service/dms.service.d.ts.map +1 -1
- package/package.json +2 -1
package/README.md
CHANGED
|
@@ -6,13 +6,14 @@ import * as i2 from "../../services/util/util.service";
|
|
|
6
6
|
import * as i3 from "../../services/dms-service/dms.service";
|
|
7
7
|
import * as i4 from "@ionic/angular";
|
|
8
8
|
import * as i5 from "../../services/captcha/captcha.service";
|
|
9
|
-
import * as i6 from "
|
|
10
|
-
import * as i7 from "
|
|
11
|
-
import * as i8 from "primeng/
|
|
12
|
-
import * as i9 from "primeng/
|
|
13
|
-
import * as i10 from "
|
|
14
|
-
import * as i11 from "
|
|
15
|
-
import * as i12 from "
|
|
9
|
+
import * as i6 from "../../services/audit/audit.service";
|
|
10
|
+
import * as i7 from "@angular/common";
|
|
11
|
+
import * as i8 from "primeng/api";
|
|
12
|
+
import * as i9 from "primeng/tooltip";
|
|
13
|
+
import * as i10 from "primeng/table";
|
|
14
|
+
import * as i11 from "@fortawesome/angular-fontawesome";
|
|
15
|
+
import * as i12 from "../overlay-info/overlay-info.component";
|
|
16
|
+
import * as i13 from "@ngx-translate/core";
|
|
16
17
|
const _c0 = ["uploadFileFormDirective"];
|
|
17
18
|
const _c1 = ["fileInput"];
|
|
18
19
|
function FileUploaderComponent_section_2_ng_template_2_th_5_Template(rf, ctx) { if (rf & 1) {
|
|
@@ -194,7 +195,7 @@ function FileUploaderComponent_section_3_Template(rf, ctx) { if (rf & 1) {
|
|
|
194
195
|
i0.ɵɵelement(3, "div", 22);
|
|
195
196
|
i0.ɵɵelementEnd();
|
|
196
197
|
i0.ɵɵelementStart(4, "ion-col")(5, "div", 13)(6, "input", 17, 15);
|
|
197
|
-
i0.ɵɵlistener("change", function FileUploaderComponent_section_3_Template_input_change_6_listener($event) { i0.ɵɵrestoreView(_r33); const ctx_r32 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r32.
|
|
198
|
+
i0.ɵɵlistener("change", function FileUploaderComponent_section_3_Template_input_change_6_listener($event) { i0.ɵɵrestoreView(_r33); const ctx_r32 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r32.uploadToTaxAudit($event)); });
|
|
198
199
|
i0.ɵɵelementEnd();
|
|
199
200
|
i0.ɵɵelementStart(8, "ion-button", 23);
|
|
200
201
|
i0.ɵɵlistener("click", function FileUploaderComponent_section_3_Template_ion_button_click_8_listener() { i0.ɵɵrestoreView(_r33); const _r31 = i0.ɵɵreference(7); return i0.ɵɵresetView(_r31.click()); });
|
|
@@ -222,12 +223,13 @@ function FileUploaderComponent_section_4_Template(rf, ctx) { if (rf & 1) {
|
|
|
222
223
|
i0.ɵɵproperty("accept", ctx_r3.allowedFileType);
|
|
223
224
|
} }
|
|
224
225
|
export class FileUploaderComponent {
|
|
225
|
-
constructor(formBuilder, util, fs, toastController, cs) {
|
|
226
|
+
constructor(formBuilder, util, fs, toastController, cs, as) {
|
|
226
227
|
this.formBuilder = formBuilder;
|
|
227
228
|
this.util = util;
|
|
228
229
|
this.fs = fs;
|
|
229
230
|
this.toastController = toastController;
|
|
230
231
|
this.cs = cs;
|
|
232
|
+
this.as = as;
|
|
231
233
|
this.imageBase64 = null;
|
|
232
234
|
this.DEFAULT_SINGLE_FILE_LIMIT = 1;
|
|
233
235
|
this.DEFAULT_FILE_SIZE_IN_MB = 1;
|
|
@@ -235,6 +237,7 @@ export class FileUploaderComponent {
|
|
|
235
237
|
this.showProgress = false;
|
|
236
238
|
this.upload = new EventEmitter();
|
|
237
239
|
this.files = new EventEmitter();
|
|
240
|
+
this.uploadAudit = new EventEmitter();
|
|
238
241
|
this.queue = [];
|
|
239
242
|
this.mapOfFiles = new Map();
|
|
240
243
|
this.multiple = false;
|
|
@@ -242,6 +245,7 @@ export class FileUploaderComponent {
|
|
|
242
245
|
this.showSeparateAttachButton = false;
|
|
243
246
|
this.noOfFilesToUpload = this.DEFAULT_SINGLE_FILE_LIMIT;
|
|
244
247
|
this.maxSizeInMB = this.DEFAULT_FILE_SIZE_IN_MB;
|
|
248
|
+
this.uploadToDMS = true;
|
|
245
249
|
this.onChange = (value) => {
|
|
246
250
|
};
|
|
247
251
|
this.onTouch = () => {
|
|
@@ -254,6 +258,8 @@ export class FileUploaderComponent {
|
|
|
254
258
|
return this.uploadFileForm.controls['uploadFileCtrl'];
|
|
255
259
|
}
|
|
256
260
|
ngOnInit() {
|
|
261
|
+
if (this.corrId) {
|
|
262
|
+
}
|
|
257
263
|
}
|
|
258
264
|
writeValue(obj) {
|
|
259
265
|
}
|
|
@@ -264,6 +270,61 @@ export class FileUploaderComponent {
|
|
|
264
270
|
this.onTouch = fn;
|
|
265
271
|
}
|
|
266
272
|
ngOnChanges(changes) {
|
|
273
|
+
if (changes['corrId']) {
|
|
274
|
+
if (this.corrId && this.context === 'signature') {
|
|
275
|
+
this.fs.getTaxAuditFile(this.corrId).subscribe((res) => {
|
|
276
|
+
this.imageBase64 = res.data;
|
|
277
|
+
this.imageHtml = `<img src="${this.imageBase64}" alt="Uploaded Image" width="385px" height="98px">`;
|
|
278
|
+
});
|
|
279
|
+
}
|
|
280
|
+
}
|
|
281
|
+
}
|
|
282
|
+
fileToBase64(file) {
|
|
283
|
+
return new Promise((resolve, reject) => {
|
|
284
|
+
const reader = new FileReader();
|
|
285
|
+
reader.readAsDataURL(file);
|
|
286
|
+
reader.onload = () => resolve(reader.result);
|
|
287
|
+
reader.onerror = error => reject(error);
|
|
288
|
+
});
|
|
289
|
+
}
|
|
290
|
+
async uploadToTaxAudit(event) {
|
|
291
|
+
const file = event.target.files[0];
|
|
292
|
+
const base64 = await this.fileToBase64(file);
|
|
293
|
+
let corId;
|
|
294
|
+
this.showProgress = true;
|
|
295
|
+
this.as.getCorrId().subscribe((res) => {
|
|
296
|
+
corId = res;
|
|
297
|
+
let req = {
|
|
298
|
+
"ean": "12345678",
|
|
299
|
+
"year": "2026",
|
|
300
|
+
"correspodenceList": [
|
|
301
|
+
{
|
|
302
|
+
"base64FileData": base64,
|
|
303
|
+
"corrId": res,
|
|
304
|
+
"direction": "INBOUND",
|
|
305
|
+
"docCode": `signature_${corId}`,
|
|
306
|
+
"mimeType": this.mimeType,
|
|
307
|
+
"title": "signature",
|
|
308
|
+
}
|
|
309
|
+
]
|
|
310
|
+
};
|
|
311
|
+
this.cs.generateCaptchaToken('file_upload').subscribe((token) => {
|
|
312
|
+
this.cs.setInvisibelCaptcha(token);
|
|
313
|
+
this.fs.uploadTaxAuditFile(req).subscribe(res => {
|
|
314
|
+
this.uploadAudit.emit(corId);
|
|
315
|
+
if (this.context === 'signature') {
|
|
316
|
+
this.imageBase64 = base64;
|
|
317
|
+
this.imageHtml = `<img src="${this.imageBase64}" alt="Uploaded Image" width="385px" height="98px">`;
|
|
318
|
+
}
|
|
319
|
+
console.log("res", res);
|
|
320
|
+
}, err => {
|
|
321
|
+
console.log("error", err);
|
|
322
|
+
this.util.errorHandler(err);
|
|
323
|
+
});
|
|
324
|
+
}, (err) => {
|
|
325
|
+
this.util.errorHandler(err);
|
|
326
|
+
});
|
|
327
|
+
});
|
|
267
328
|
}
|
|
268
329
|
addToQueue(event) {
|
|
269
330
|
let currFileUpldSize = 0;
|
|
@@ -297,6 +358,15 @@ export class FileUploaderComponent {
|
|
|
297
358
|
}
|
|
298
359
|
let files = [...event.target.files];
|
|
299
360
|
event.target.value = '';
|
|
361
|
+
if (!this.uploadToDMS) {
|
|
362
|
+
// let files = [...event.target.files];
|
|
363
|
+
for (var i = 0; i < files.length; i++) {
|
|
364
|
+
// this.queue.push(files[i]);
|
|
365
|
+
this.mapOfFiles.set(files[i], null);
|
|
366
|
+
}
|
|
367
|
+
this.files.emit(this.mapOfFiles);
|
|
368
|
+
return;
|
|
369
|
+
}
|
|
300
370
|
this.fs
|
|
301
371
|
.uploadFile(formData)
|
|
302
372
|
.subscribe(res => {
|
|
@@ -382,7 +452,7 @@ export class FileUploaderComponent {
|
|
|
382
452
|
error(msg) {
|
|
383
453
|
this.presentToast(msg, 'danger');
|
|
384
454
|
}
|
|
385
|
-
static { this.ɵfac = function FileUploaderComponent_Factory(t) { return new (t || FileUploaderComponent)(i0.ɵɵdirectiveInject(i1.UntypedFormBuilder), i0.ɵɵdirectiveInject(i2.UtilService), i0.ɵɵdirectiveInject(i3.DmsService), i0.ɵɵdirectiveInject(i4.ToastController), i0.ɵɵdirectiveInject(i5.CaptchaService)); }; }
|
|
455
|
+
static { this.ɵfac = function FileUploaderComponent_Factory(t) { return new (t || FileUploaderComponent)(i0.ɵɵdirectiveInject(i1.UntypedFormBuilder), i0.ɵɵdirectiveInject(i2.UtilService), i0.ɵɵdirectiveInject(i3.DmsService), i0.ɵɵdirectiveInject(i4.ToastController), i0.ɵɵdirectiveInject(i5.CaptchaService), i0.ɵɵdirectiveInject(i6.AuditService)); }; }
|
|
386
456
|
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: FileUploaderComponent, selectors: [["app-file-uploader"]], viewQuery: function FileUploaderComponent_Query(rf, ctx) { if (rf & 1) {
|
|
387
457
|
i0.ɵɵviewQuery(_c0, 5);
|
|
388
458
|
i0.ɵɵviewQuery(_c1, 5);
|
|
@@ -390,7 +460,7 @@ export class FileUploaderComponent {
|
|
|
390
460
|
let _t;
|
|
391
461
|
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.uploadFileFormDirective = _t.first);
|
|
392
462
|
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.fileInput = _t);
|
|
393
|
-
} }, inputs: { allowedFileType: "allowedFileType", multiple: "multiple", proofOfAnything: "proofOfAnything", context: "context", showSeparateAttachButton: "showSeparateAttachButton", noOfFilesToUpload: "noOfFilesToUpload", maxSizeInMB: "maxSizeInMB" }, outputs: { upload: "upload", files: "files" }, features: [i0.ɵɵProvidersFeature([{
|
|
463
|
+
} }, inputs: { allowedFileType: "allowedFileType", mimeType: "mimeType", multiple: "multiple", proofOfAnything: "proofOfAnything", context: "context", showSeparateAttachButton: "showSeparateAttachButton", noOfFilesToUpload: "noOfFilesToUpload", maxSizeInMB: "maxSizeInMB", uploadToDMS: "uploadToDMS", corrId: "corrId" }, outputs: { upload: "upload", files: "files", uploadAudit: "uploadAudit" }, features: [i0.ɵɵProvidersFeature([{
|
|
394
464
|
provide: NG_VALUE_ACCESSOR,
|
|
395
465
|
useExisting: FileUploaderComponent,
|
|
396
466
|
multi: true
|
|
@@ -406,7 +476,7 @@ export class FileUploaderComponent {
|
|
|
406
476
|
i0.ɵɵproperty("ngIf", ctx.context == "signature");
|
|
407
477
|
i0.ɵɵadvance(1);
|
|
408
478
|
i0.ɵɵproperty("ngIf", ctx.context == "uploadZipCodes");
|
|
409
|
-
} }, dependencies: [i4.IonButton, i4.IonCol, i4.IonIcon, i4.IonRow,
|
|
479
|
+
} }, dependencies: [i4.IonButton, i4.IonCol, i4.IonIcon, i4.IonRow, i7.NgIf, i8.PrimeTemplate, i9.Tooltip, i1.ɵNgNoValidate, i1.DefaultValueAccessor, i1.NgControlStatus, i1.NgControlStatusGroup, i1.FormGroupDirective, i1.FormControlName, i10.Table, i11.FaIconComponent, i12.OverlayInfoComponent, i7.DecimalPipe, i13.TranslatePipe], styles: [".file-input-container[_ngcontent-%COMP%]{text-align:right}.file-input-container[_ngcontent-%COMP%] input[type=file][_ngcontent-%COMP%]{display:none}.file-input-container[_ngcontent-%COMP%] label[_ngcontent-%COMP%]{border:1px solid #ccc;padding:6px 12px;cursor:pointer}.upload-input-container[_ngcontent-%COMP%] input[type=file][_ngcontent-%COMP%]{display:none}.upload-input-container[_ngcontent-%COMP%] label[_ngcontent-%COMP%]{border:1px solid #ccc;cursor:pointer}[_nghost-%COMP%] .p-datatable .p-datatable-thead>tr>th{background:#fff!important;background-color:#fff!important}ol[_ngcontent-%COMP%], ul[_ngcontent-%COMP%]{list-style:none}ul[_ngcontent-%COMP%]{list-style-type:square}li[_ngcontent-%COMP%]{color:var(--ion-color-grey)}"] }); }
|
|
410
480
|
}
|
|
411
481
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(FileUploaderComponent, [{
|
|
412
482
|
type: Component,
|
|
@@ -414,19 +484,23 @@ export class FileUploaderComponent {
|
|
|
414
484
|
provide: NG_VALUE_ACCESSOR,
|
|
415
485
|
useExisting: FileUploaderComponent,
|
|
416
486
|
multi: true
|
|
417
|
-
}], template: "<form [formGroup]=\"uploadFileForm\" #uploadFileFormDirective=\"ngForm\">\r\n <section *ngIf=\"this.context != 'signature' && this.context !='uploadZipCodes'\">\r\n <p-table [value]=\"queue\" responsiveLayout=\"scroll\" [loading]=\"showProgress\">\r\n <ng-template pTemplate=\"header\">\r\n <tr>\r\n <th>Name</th>\r\n <th>Size</th>\r\n <th style=\"text-align:right\" *ngIf=\"proofOfAnything\">\r\n <app-overlay-info overlayText=\"{{'proof.of.anything.info'| translate}}\"\r\n style=\"margin-top: 2px; margin-left: 6px;\"></app-overlay-info>\r\n </th>\r\n <th class=\"ion-text-right\">\r\n <div class=\"file-input-container\" *ngIf=\"multiple && !proofOfAnything\">\r\n <input type=\"file\" #fileInput formControlName=\"uploadFileCtrl\" [accept]=\"allowedFileType\"\r\n multiple=\"multiple\" (change)=\"addToQueue($event)\" />\r\n <ion-button shape=\"round\" size=\"small\" type=\"submit\" fill=\"outline\" (click)=\"fileInput.click()\">\r\n Choose Files\r\n </ion-button>\r\n </div>\r\n\r\n <div class=\"file-input-container\" *ngIf=\"!multiple && !proofOfAnything\">\r\n <input type=\"file\" #fileInput formControlName=\"uploadFileCtrl\" [accept]=\"allowedFileType\"\r\n (change)=\"addToQueue($event)\" />\r\n <ion-button shape=\"round\" size=\"small\" type=\"submit\" fill=\"outline\" (click)=\"fileInput.click()\">\r\n Choose File\r\n </ion-button>\r\n </div>\r\n </th>\r\n </tr>\r\n </ng-template>\r\n <ng-template pTemplate=\"body\" let-queue>\r\n <tr>\r\n <td>{{ queue?.name }}</td>\r\n <td>{{ queue?.size/1024/1024 | number:'.2' }} MB</td>\r\n <td class=\"ion-text-right\">\r\n <ion-button shape=\"round\" size=\"small\" pTooltip=\"Remove\" (click)=\"removeFromQueue(queue)\"\r\n tooltipPosition=\"bottom\" class=\"ion-padding-left\">\r\n <ion-icon name=\"trash-outline\"></ion-icon>\r\n </ion-button>\r\n </td>\r\n </tr>\r\n </ng-template>\r\n <ng-template pTemplate=\"emptymessage\">\r\n <tr *ngIf=\"!proofOfAnything\">\r\n <td [attr.colspan]=\"3\">\r\n <ul>\r\n <li *ngIf=\"allowedFileType\">You are allowed to upload file(s) with following extentions: {{allowedFileType}}.</li>\r\n <li>Total file(s) size cannot exceed <b>{{maxSizeInMB}}</b> MB.</li>\r\n <li>You can upload maximum <b>{{noOfFilesToUpload}}</b> file(s).</li>\r\n </ul>\r\n </td>\r\n </tr>\r\n </ng-template>\r\n <ng-template pTemplate=\"footer\"> \r\n <tr *ngIf=\"proofOfAnything\">\r\n <td *ngIf=\"queue.length == 0\">\r\n <div><b>+ Add</b> files</div>\r\n </td>\r\n <td *ngIf=\"queue.length > 0\">\r\n <div><b>+ Add</b> any other files</div>\r\n </td>\r\n <td></td>\r\n <td class=\"file-input-container\">\r\n <input type=\"file\" #fileInput formControlName=\"uploadFileCtrl\" [accept]=\"allowedFileType\"\r\n (change)=\"addToQueue($event)\" />\r\n <ion-button aria-label=\"Add Files\" (click)=\"fileInput.click()\" fill=\"outline\" size=\"small\" class=\"action-button\">\r\n <fa-icon [icon]=\"['fal', 'plus']\" class=\"action-icon\"></fa-icon>\r\n </ion-button>\r\n </td>\r\n </tr>\r\n </ng-template>\r\n </p-table>\r\n</section>\r\n<section *ngIf=\"this.context == 'signature'\">\r\n <ion-row>\r\n <ion-col>\r\n <div [innerHTML]=\"imageHtml\" style=\"width: 385px; height: 100px; border: 1px solid gray; justify-content: center; align-items: center;\"></div>\r\n </ion-col>\r\n <ion-col>\r\n <div class=\"file-input-container\">\r\n <input type=\"file\" #fileInput formControlName=\"uploadFileCtrl\" [accept]=\"allowedFileType\"\r\n (change)=\"
|
|
418
|
-
}], () => [{ type: i1.UntypedFormBuilder }, { type: i2.UtilService }, { type: i3.DmsService }, { type: i4.ToastController }, { type: i5.CaptchaService }], { uploadFileFormDirective: [{
|
|
487
|
+
}], template: "<form [formGroup]=\"uploadFileForm\" #uploadFileFormDirective=\"ngForm\">\r\n <section *ngIf=\"this.context != 'signature' && this.context !='uploadZipCodes'\">\r\n <p-table [value]=\"queue\" responsiveLayout=\"scroll\" [loading]=\"showProgress\">\r\n <ng-template pTemplate=\"header\">\r\n <tr>\r\n <th>Name</th>\r\n <th>Size</th>\r\n <th style=\"text-align:right\" *ngIf=\"proofOfAnything\">\r\n <app-overlay-info overlayText=\"{{'proof.of.anything.info'| translate}}\"\r\n style=\"margin-top: 2px; margin-left: 6px;\"></app-overlay-info>\r\n </th>\r\n <th class=\"ion-text-right\">\r\n <div class=\"file-input-container\" *ngIf=\"multiple && !proofOfAnything\">\r\n <input type=\"file\" #fileInput formControlName=\"uploadFileCtrl\" [accept]=\"allowedFileType\"\r\n multiple=\"multiple\" (change)=\"addToQueue($event)\" />\r\n <ion-button shape=\"round\" size=\"small\" type=\"submit\" fill=\"outline\" (click)=\"fileInput.click()\">\r\n Choose Files\r\n </ion-button>\r\n </div>\r\n\r\n <div class=\"file-input-container\" *ngIf=\"!multiple && !proofOfAnything\">\r\n <input type=\"file\" #fileInput formControlName=\"uploadFileCtrl\" [accept]=\"allowedFileType\"\r\n (change)=\"addToQueue($event)\" />\r\n <ion-button shape=\"round\" size=\"small\" type=\"submit\" fill=\"outline\" (click)=\"fileInput.click()\">\r\n Choose File\r\n </ion-button>\r\n </div>\r\n </th>\r\n </tr>\r\n </ng-template>\r\n <ng-template pTemplate=\"body\" let-queue>\r\n <tr>\r\n <td>{{ queue?.name }}</td>\r\n <td>{{ queue?.size/1024/1024 | number:'.2' }} MB</td>\r\n <td class=\"ion-text-right\">\r\n <ion-button shape=\"round\" size=\"small\" pTooltip=\"Remove\" (click)=\"removeFromQueue(queue)\"\r\n tooltipPosition=\"bottom\" class=\"ion-padding-left\">\r\n <ion-icon name=\"trash-outline\"></ion-icon>\r\n </ion-button>\r\n </td>\r\n </tr>\r\n </ng-template>\r\n <ng-template pTemplate=\"emptymessage\">\r\n <tr *ngIf=\"!proofOfAnything\">\r\n <td [attr.colspan]=\"3\">\r\n <ul>\r\n <li *ngIf=\"allowedFileType\">You are allowed to upload file(s) with following extentions: {{allowedFileType}}.</li>\r\n <li>Total file(s) size cannot exceed <b>{{maxSizeInMB}}</b> MB.</li>\r\n <li>You can upload maximum <b>{{noOfFilesToUpload}}</b> file(s).</li>\r\n </ul>\r\n </td>\r\n </tr>\r\n </ng-template>\r\n <ng-template pTemplate=\"footer\"> \r\n <tr *ngIf=\"proofOfAnything\">\r\n <td *ngIf=\"queue.length == 0\">\r\n <div><b>+ Add</b> files</div>\r\n </td>\r\n <td *ngIf=\"queue.length > 0\">\r\n <div><b>+ Add</b> any other files</div>\r\n </td>\r\n <td></td>\r\n <td class=\"file-input-container\">\r\n <input type=\"file\" #fileInput formControlName=\"uploadFileCtrl\" [accept]=\"allowedFileType\"\r\n (change)=\"addToQueue($event)\" />\r\n <ion-button aria-label=\"Add Files\" (click)=\"fileInput.click()\" fill=\"outline\" size=\"small\" class=\"action-button\">\r\n <fa-icon [icon]=\"['fal', 'plus']\" class=\"action-icon\"></fa-icon>\r\n </ion-button>\r\n </td>\r\n </tr>\r\n </ng-template>\r\n </p-table>\r\n</section>\r\n<section *ngIf=\"this.context == 'signature'\">\r\n <ion-row>\r\n <ion-col>\r\n <div [innerHTML]=\"imageHtml\" style=\"width: 385px; height: 100px; border: 1px solid gray; justify-content: center; align-items: center;\"></div>\r\n </ion-col>\r\n <ion-col>\r\n <div class=\"file-input-container\">\r\n <input type=\"file\" #fileInput formControlName=\"uploadFileCtrl\" [accept]=\"allowedFileType\"\r\n (change)=\"uploadToTaxAudit($event)\" />\r\n <ion-button shape=\"square\" size=\"small\" type=\"submit\" fill=\"outline\" (click)=\"fileInput.click()\">\r\n Import\r\n </ion-button>\r\n </div>\r\n </ion-col>\r\n </ion-row>\r\n</section>\r\n<section *ngIf=\"this.context == 'uploadZipCodes'\">\r\n <div class=\"upload-input-container\">\r\n <input type=\"file\" #fileInput formControlName=\"uploadFileCtrl\" [accept]=\"allowedFileType\"\r\n (change)=\"addToQueue($event)\" />\r\n <ion-button shape=\"square\" size=\"default\" type=\"submit\" fill=\"outline\" (click)=\"fileInput.click()\">\r\n Upload Zip Codes\r\n </ion-button>\r\n </div>\r\n</section>\r\n</form>", styles: [".file-input-container{text-align:right}.file-input-container input[type=file]{display:none}.file-input-container label{border:1px solid #ccc;padding:6px 12px;cursor:pointer}.upload-input-container input[type=file]{display:none}.upload-input-container label{border:1px solid #ccc;cursor:pointer}:host ::ng-deep .p-datatable .p-datatable-thead>tr>th{background:#fff!important;background-color:#fff!important}ol,ul{list-style:none}ul{list-style-type:square}li{color:var(--ion-color-grey)}\n"] }]
|
|
488
|
+
}], () => [{ type: i1.UntypedFormBuilder }, { type: i2.UtilService }, { type: i3.DmsService }, { type: i4.ToastController }, { type: i5.CaptchaService }, { type: i6.AuditService }], { uploadFileFormDirective: [{
|
|
419
489
|
type: ViewChild,
|
|
420
490
|
args: ['uploadFileFormDirective', { static: false }]
|
|
421
491
|
}], upload: [{
|
|
422
492
|
type: Output
|
|
423
493
|
}], files: [{
|
|
424
494
|
type: Output
|
|
495
|
+
}], uploadAudit: [{
|
|
496
|
+
type: Output
|
|
425
497
|
}], fileInput: [{
|
|
426
498
|
type: ViewChildren,
|
|
427
499
|
args: ['fileInput']
|
|
428
500
|
}], allowedFileType: [{
|
|
429
501
|
type: Input
|
|
502
|
+
}], mimeType: [{
|
|
503
|
+
type: Input
|
|
430
504
|
}], multiple: [{
|
|
431
505
|
type: Input
|
|
432
506
|
}], proofOfAnything: [{
|
|
@@ -439,6 +513,10 @@ export class FileUploaderComponent {
|
|
|
439
513
|
type: Input
|
|
440
514
|
}], maxSizeInMB: [{
|
|
441
515
|
type: Input
|
|
516
|
+
}], uploadToDMS: [{
|
|
517
|
+
type: Input
|
|
518
|
+
}], corrId: [{
|
|
519
|
+
type: Input
|
|
442
520
|
}] }); })();
|
|
443
521
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(FileUploaderComponent, { className: "FileUploaderComponent", filePath: "lib\\components\\file-uploader\\file-uploader.component.ts", lineNumber: 20 }); })();
|
|
444
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-uploader.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-reusa-app-lib/src/lib/components/file-uploader/file-uploader.component.ts","../../../../../../projects/ngx-reusa-app-lib/src/lib/components/file-uploader/file-uploader.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, OnInit, Output, ViewChildren, Input, OnChanges, SimpleChanges, ViewChild } from '@angular/core';\nimport { ControlValueAccessor, UntypedFormBuilder, UntypedFormGroup, NgForm, NG_VALUE_ACCESSOR, Validators } from '@angular/forms';\nimport { ToastController } from '@ionic/angular';\nimport { UtilService } from '../../services/util/util.service';\nimport { CaptchaService } from '../../services/captcha/captcha.service';\nimport { DmsService } from '../../services/dms-service/dms.service';\n\n\n\n@Component({\n  selector: 'app-file-uploader',\n  templateUrl: './file-uploader.component.html',\n  styleUrls: ['./file-uploader.component.scss'],\n  providers: [{\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: FileUploaderComponent,\n    multi: true\n  }]\n})\nexport class FileUploaderComponent implements OnInit, ControlValueAccessor, OnChanges {\n\n  imageBase64: string | null = null;\n\n  private DEFAULT_SINGLE_FILE_LIMIT = 1;\n\n  private DEFAULT_FILE_SIZE_IN_MB = 1;\n\n  private FILE_UPLOAD_ACTION_NAME = 'file_upload';\n\n  public showProgress = false;\n\n  @ViewChild('uploadFileFormDirective', { static: false })\n  public uploadFileFormDirective: NgForm;\n\n  @Output()\n  upload: EventEmitter<any> = new EventEmitter();\n\n  @Output()\n  files: EventEmitter<Map<File, string>> = new EventEmitter();\n\n  @ViewChildren('fileInput') fileInput;\n\n  queue: File[] = [];\n\n  mapOfFiles: Map<File, string> = new Map();\n\n  @Input()\n  allowedFileType: string;\n\n  @Input()\n  multiple: boolean = false;\n\n  @Input()\n  proofOfAnything: boolean = false;\n\n  @Input()\n  context: string;\n\n  @Input()\n  showSeparateAttachButton: boolean = false;\n\n  @Input()\n  noOfFilesToUpload: number = this.DEFAULT_SINGLE_FILE_LIMIT;\n\n  @Input()\n  maxSizeInMB: number = this.DEFAULT_FILE_SIZE_IN_MB;\n\n  \n  public uploadFileForm: UntypedFormGroup;\n  imageHtml: string;\n\n  constructor(public formBuilder: UntypedFormBuilder, private util: UtilService, private fs: DmsService, \n    public toastController: ToastController, private cs: CaptchaService) {\n    this.uploadFileForm = this.formBuilder.group({\n      'uploadFileCtrl': [null, Validators.required]\n    });\n  }\n\n  get uploadFileCtrl() {\n    return this.uploadFileForm.controls['uploadFileCtrl'];\n  }\n\n\n  ngOnInit() {\n  }\n\n  private onChange: Function = (value: String) => {\n\n  };\n  private onTouch: Function = () => {\n\n  };\n  writeValue(obj: any): void {\n  }\n\n  registerOnChange(fn: any): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouch = fn;\n  }\n\n\n  ngOnChanges(changes: SimpleChanges): void {\n\n  }\n\n  addToQueue(event) {\n    let currFileUpldSize: number = 0;\n    let preFileUpldSize: number = 0;\n    let maxSizeReached: Boolean = false;\n    let curUpldFileLen: number = event.target.files.length;\n    let preUpldFileLen: number = this.queue.length;\n\n    if ((curUpldFileLen + preUpldFileLen) > this.noOfFilesToUpload) {\n      this.error(\"You can not upload more than \" + this.noOfFilesToUpload + \" file(s).\");\n      return;\n    }\n\n    for (var i = 0; i < this.queue.length; i++) {\n      preFileUpldSize = this.getSizeInMB(this.queue[i].size) + preFileUpldSize;\n    }\n\n    for (var i = 0; i < event.target.files.length; i++) {\n      currFileUpldSize = currFileUpldSize + this.getSizeInMB(event.target.files[i].size)\n    }\n\n    maxSizeReached = (preFileUpldSize + currFileUpldSize > this.maxSizeInMB);\n\n    if (maxSizeReached) {\n      this.error('Combined file(s) size can not be more than ' + this.maxSizeInMB + ' MB.');\n      return;\n    }\n\n    this.showProgress = true;\n    this.cs.generateCaptchaToken(this.FILE_UPLOAD_ACTION_NAME)\n      .subscribe((token: string) => {\n        this.cs.setInvisibelCaptcha(token);\n        if (!maxSizeReached) {\n          const formData: FormData = new FormData();\n          for (var i = 0; i < event.target.files.length; i++) {\n            formData.append(\"files\", event.target.files[i], event.target.files[i].name);\n          }\n          let files = [...event.target.files];\n          event.target.value = '';\n          this.fs\n            .uploadFile(formData)\n            .subscribe(\n              res => {\n                for (var i = 0; i < files.length; i++) {\n                  this.queue.push(files[i]);\n                  this.mapOfFiles.set(files[i], res[i].fileId);\n                }\n                this.onChange(Array.from(this.mapOfFiles.values()));\n                this.success('File(s) uploaded successfully.');\n\t\t                //Specifically for Signature-Upload (Will be move to a new method)\n                const file = (this.mapOfFiles.entries().next().value)[0];\n                if (file && (file.type === 'image/png' || file.type === 'image/jpeg' \n                  || file.type === 'image/gif')) {\n                  const reader = new FileReader();\n                  reader.onload = (e: any) => {\n                    this.imageBase64 = e.target.result;\n                    this.imageHtml = `<img src=\"${this.imageBase64}\" alt=\"Uploaded Image\" width=\"125\" height=\"75\">`;\n                  };\n                  reader.readAsDataURL(file);\n                }\n                //\n                this.showProgress = false;\n                this.upload.emit(Array.from(this.mapOfFiles.values()));\n                this.files.emit(this.mapOfFiles);\n              },\n              err => {\n                this.showProgress = false;\n                this.error(\"File upload failed. Please try again.\");\n                console.log(err);\n              });\n        }\n      }, err => {\n        this.showProgress = true;\n        this.error(\"File upload failed. Please try again.\");\n        console.log(err);\n      });\n  }\n\n  removeFromQueue(fileToRemove) {\n    let index;\n    for (var i = 0; i < this.queue.length; i++) {\n      if (this.queue[i].name === fileToRemove.name) {\n        index = i;\n      }\n    }\n    this.showProgress = true;\n    let fileId = this.mapOfFiles.get(fileToRemove);\n    this.cs.generateCaptchaToken(this.FILE_UPLOAD_ACTION_NAME)\n      .subscribe((token: string) => {\n        this.cs.setInvisibelCaptcha(token);\n        this.fs.deleteFile(fileId)\n          .subscribe(res => {\n            this.queue.splice(index, 1);\n            this.mapOfFiles.delete(fileToRemove);\n            this.showProgress = false;\n            this.onChange(Array.from(this.mapOfFiles.values()));\n            this.upload.emit(Array.from(this.mapOfFiles.values()))\n            this.files.emit(this.mapOfFiles);\n          }, err => {\n            this.showProgress = false;\n            this.error(\"Error while deleting file. Please try again.\");\n            console.log(err);\n          })\n      }, err => {\n        this.showProgress = false;\n        this.error(\"Error while deleting file. Please try again.\");\n        console.log(err);\n      });\n\n  }\n\n  getSizeInMB(num: number) {\n    return num / 1024 / 1024\n  }\n\n  async presentToast(msg, color) {\n    const toast = await this.toastController.create({\n      message: msg,\n      duration: 5000,\n      color: color,\n      position: 'bottom'\n    });\n    toast.present();\n  }\n\n  success(msg) {\n    this.presentToast(msg, 'primary');\n  }\n\n  error(msg) {\n    this.presentToast(msg, 'danger');\n  }\n\n}\n","<form [formGroup]=\"uploadFileForm\" #uploadFileFormDirective=\"ngForm\">\r\n  <section *ngIf=\"this.context != 'signature' && this.context !='uploadZipCodes'\">\r\n  <p-table [value]=\"queue\" responsiveLayout=\"scroll\" [loading]=\"showProgress\">\r\n    <ng-template pTemplate=\"header\">\r\n      <tr>\r\n        <th>Name</th>\r\n        <th>Size</th>\r\n        <th style=\"text-align:right\" *ngIf=\"proofOfAnything\">\r\n          <app-overlay-info overlayText=\"{{'proof.of.anything.info'| translate}}\"\r\n          style=\"margin-top: 2px; margin-left: 6px;\"></app-overlay-info>\r\n        </th>\r\n        <th class=\"ion-text-right\">\r\n          <div class=\"file-input-container\" *ngIf=\"multiple && !proofOfAnything\">\r\n            <input type=\"file\" #fileInput formControlName=\"uploadFileCtrl\" [accept]=\"allowedFileType\"\r\n              multiple=\"multiple\" (change)=\"addToQueue($event)\" />\r\n            <ion-button shape=\"round\" size=\"small\" type=\"submit\" fill=\"outline\" (click)=\"fileInput.click()\">\r\n              Choose Files\r\n            </ion-button>\r\n          </div>\r\n\r\n          <div class=\"file-input-container\" *ngIf=\"!multiple && !proofOfAnything\">\r\n            <input type=\"file\" #fileInput formControlName=\"uploadFileCtrl\" [accept]=\"allowedFileType\"\r\n              (change)=\"addToQueue($event)\" />\r\n            <ion-button shape=\"round\" size=\"small\" type=\"submit\" fill=\"outline\" (click)=\"fileInput.click()\">\r\n              Choose File\r\n            </ion-button>\r\n          </div>\r\n        </th>\r\n      </tr>\r\n    </ng-template>\r\n    <ng-template pTemplate=\"body\" let-queue>\r\n      <tr>\r\n        <td>{{ queue?.name }}</td>\r\n        <td>{{ queue?.size/1024/1024 | number:'.2' }} MB</td>\r\n        <td class=\"ion-text-right\">\r\n          <ion-button shape=\"round\" size=\"small\" pTooltip=\"Remove\" (click)=\"removeFromQueue(queue)\"\r\n            tooltipPosition=\"bottom\" class=\"ion-padding-left\">\r\n            <ion-icon name=\"trash-outline\"></ion-icon>\r\n          </ion-button>\r\n        </td>\r\n      </tr>\r\n    </ng-template>\r\n    <ng-template pTemplate=\"emptymessage\">\r\n      <tr *ngIf=\"!proofOfAnything\">\r\n        <td [attr.colspan]=\"3\">\r\n            <ul>\r\n              <li *ngIf=\"allowedFileType\">You are allowed to upload file(s) with following extentions: {{allowedFileType}}.</li>\r\n              <li>Total file(s) size cannot exceed <b>{{maxSizeInMB}}</b> MB.</li>\r\n              <li>You can upload maximum <b>{{noOfFilesToUpload}}</b> file(s).</li>\r\n            </ul>\r\n        </td>\r\n      </tr>\r\n    </ng-template>\r\n    <ng-template pTemplate=\"footer\"> \r\n      <tr *ngIf=\"proofOfAnything\">\r\n        <td *ngIf=\"queue.length == 0\">\r\n          <div><b>+ Add</b> files</div>\r\n        </td>\r\n        <td *ngIf=\"queue.length > 0\">\r\n          <div><b>+ Add</b> any other files</div>\r\n        </td>\r\n        <td></td>\r\n        <td class=\"file-input-container\">\r\n            <input type=\"file\" #fileInput formControlName=\"uploadFileCtrl\" [accept]=\"allowedFileType\"\r\n              (change)=\"addToQueue($event)\" />\r\n            <ion-button aria-label=\"Add Files\" (click)=\"fileInput.click()\" fill=\"outline\" size=\"small\" class=\"action-button\">\r\n              <fa-icon [icon]=\"['fal', 'plus']\" class=\"action-icon\"></fa-icon>\r\n            </ion-button>\r\n        </td>\r\n      </tr>\r\n    </ng-template>\r\n  </p-table>\r\n</section>\r\n<section *ngIf=\"this.context == 'signature'\">\r\n  <ion-row>\r\n    <ion-col>\r\n      <div [innerHTML]=\"imageHtml\" style=\"width: 385px; height: 100px; border: 1px solid gray; justify-content: center; align-items: center;\"></div>\r\n    </ion-col>\r\n    <ion-col>\r\n      <div class=\"file-input-container\">\r\n        <input type=\"file\" #fileInput formControlName=\"uploadFileCtrl\" [accept]=\"allowedFileType\"\r\n          (change)=\"addToQueue($event)\" />\r\n        <ion-button shape=\"square\" size=\"small\" type=\"submit\" fill=\"outline\" (click)=\"fileInput.click()\">\r\n          Import\r\n        </ion-button>\r\n      </div>\r\n    </ion-col>\r\n  </ion-row>\r\n</section>\r\n<section *ngIf=\"this.context == 'uploadZipCodes'\">\r\n  <div class=\"upload-input-container\">\r\n    <input type=\"file\" #fileInput formControlName=\"uploadFileCtrl\" [accept]=\"allowedFileType\"\r\n      (change)=\"addToQueue($event)\" />\r\n    <ion-button shape=\"square\" size=\"default\" type=\"submit\" fill=\"outline\" (click)=\"fileInput.click()\">\r\n      Upload Zip Codes\r\n    </ion-button>\r\n  </div>\r\n</section>\r\n</form>"]}
|
|
522
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-uploader.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-reusa-app-lib/src/lib/components/file-uploader/file-uploader.component.ts","../../../../../../projects/ngx-reusa-app-lib/src/lib/components/file-uploader/file-uploader.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, OnInit, Output, ViewChildren, Input, OnChanges, SimpleChanges, ViewChild } from '@angular/core';\nimport { ControlValueAccessor, UntypedFormBuilder, UntypedFormGroup, NgForm, NG_VALUE_ACCESSOR, Validators } from '@angular/forms';\nimport { ToastController } from '@ionic/angular';\nimport { UtilService } from '../../services/util/util.service';\nimport { CaptchaService } from '../../services/captcha/captcha.service';\nimport { DmsService } from '../../services/dms-service/dms.service';\nimport { AuditService } from '../../services/audit/audit.service';\n\n\n@Component({\n  selector: 'app-file-uploader',\n  templateUrl: './file-uploader.component.html',\n  styleUrls: ['./file-uploader.component.scss'],\n  providers: [{\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: FileUploaderComponent,\n    multi: true\n  }]\n})\nexport class FileUploaderComponent implements OnInit, ControlValueAccessor, OnChanges {\n\n  imageBase64: string | null = null;\n\n  private DEFAULT_SINGLE_FILE_LIMIT = 1;\n\n  private DEFAULT_FILE_SIZE_IN_MB = 1;\n\n  private FILE_UPLOAD_ACTION_NAME = 'file_upload';\n\n  public showProgress = false;\n\n  @ViewChild('uploadFileFormDirective', { static: false })\n  public uploadFileFormDirective: NgForm;\n\n  @Output()\n  upload: EventEmitter<any> = new EventEmitter();\n\n  @Output()\n  files: EventEmitter<Map<File, string>> = new EventEmitter();\n\n  @Output()\n  uploadAudit: EventEmitter<any> = new EventEmitter();\n\n  @ViewChildren('fileInput') fileInput;\n\n  queue: File[] = [];\n\n  mapOfFiles: Map<File, string> = new Map();\n\n  @Input()\n  allowedFileType: string;\n\n  @Input()\n  mimeType:string;\n\n  @Input()\n  multiple: boolean = false;\n\n  @Input()\n  proofOfAnything: boolean = false;\n\n  @Input()\n  context: string;\n\n  @Input()\n  showSeparateAttachButton: boolean = false;\n\n  @Input()\n  noOfFilesToUpload: number = this.DEFAULT_SINGLE_FILE_LIMIT;\n\n  @Input()\n  maxSizeInMB: number = this.DEFAULT_FILE_SIZE_IN_MB;\n\n  @Input()\n  uploadToDMS:boolean = true;\n\n  @Input()\n  corrId;\n  \n  public uploadFileForm: UntypedFormGroup;\n  imageHtml: string;\n\n  constructor(public formBuilder: UntypedFormBuilder, private util: UtilService, private fs: DmsService, \n    public toastController: ToastController, private cs: CaptchaService, private as: AuditService) {\n    this.uploadFileForm = this.formBuilder.group({\n      'uploadFileCtrl': [null, Validators.required]\n    });\n  }\n\n  get uploadFileCtrl() {\n    return this.uploadFileForm.controls['uploadFileCtrl'];\n  }\n\n\n  ngOnInit() {\n    if(this.corrId){\n\n    }\n  }\n\n  private onChange: Function = (value: String) => {\n\n  };\n  private onTouch: Function = () => {\n\n  };\n  writeValue(obj: any): void {\n  }\n\n  registerOnChange(fn: any): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouch = fn;\n  }\n\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['corrId']) {\n      if(this.corrId && this.context==='signature'){\n        this.fs.getTaxAuditFile(this.corrId).subscribe((res)=>{\n          this.imageBase64 = res.data;\n          this.imageHtml = `<img src=\"${this.imageBase64}\" alt=\"Uploaded Image\" width=\"385px\" height=\"98px\">`;\n        })\n      }\n    }\n  }\n  fileToBase64(file: File): Promise<string> {\n    return new Promise((resolve, reject) => {\n      const reader = new FileReader();\n      reader.readAsDataURL(file);\n\n      reader.onload = () => resolve(reader.result as string);\n      reader.onerror = error => reject(error);\n    });\n  }\n  async uploadToTaxAudit (event){\n    const file = event.target.files[0];\n    const base64 = await this.fileToBase64(file);\n    let corId; \n    this.showProgress = true;\n    \n    this.as.getCorrId().subscribe((res)=>{\n      corId = res;\n      let req = {\n           \"ean\": \"12345678\",\n            \"year\": \"2026\",\n             \"correspodenceList\": [\n              {\n                \"base64FileData\":base64,\n                \"corrId\": res,\n                \"direction\": \"INBOUND\",\n                \"docCode\": `signature_${corId}`,\n                \"mimeType\": this.mimeType,\n                \"title\": \"signature\",\n              }\n             ]\n      }\n      this.cs.generateCaptchaToken('file_upload').subscribe((token: string) => {\n            this.cs.setInvisibelCaptcha(token);\n            this.fs.uploadTaxAuditFile(req).subscribe(res=>{\n              this.uploadAudit.emit(corId)\n              if(this.context==='signature'){\n                this.imageBase64 = base64;\n                this.imageHtml = `<img src=\"${this.imageBase64}\" alt=\"Uploaded Image\" width=\"385px\" height=\"98px\">`;\n              }\n              console.log(\"res\",res)\n            },err=>{\n              console.log(\"error\",err);\n              this.util.errorHandler(err);\n              \n            })\n       },(err)=>{\n            this.util.errorHandler(err);\n          })\n    })\n  }\n\n  addToQueue(event) {\n    let currFileUpldSize: number = 0;\n    let preFileUpldSize: number = 0;\n    let maxSizeReached: Boolean = false;\n    let curUpldFileLen: number = event.target.files.length;\n    let preUpldFileLen: number = this.queue.length;\n\n    if ((curUpldFileLen + preUpldFileLen) > this.noOfFilesToUpload) {\n      this.error(\"You can not upload more than \" + this.noOfFilesToUpload + \" file(s).\");\n      return;\n    }\n\n    for (var i = 0; i < this.queue.length; i++) {\n      preFileUpldSize = this.getSizeInMB(this.queue[i].size) + preFileUpldSize;\n    }\n\n    for (var i = 0; i < event.target.files.length; i++) {\n      currFileUpldSize = currFileUpldSize + this.getSizeInMB(event.target.files[i].size)\n    }\n\n    maxSizeReached = (preFileUpldSize + currFileUpldSize > this.maxSizeInMB);\n\n    if (maxSizeReached) {\n      this.error('Combined file(s) size can not be more than ' + this.maxSizeInMB + ' MB.');\n      return;\n    }\n\n    this.showProgress = true;\n    \n    this.cs.generateCaptchaToken(this.FILE_UPLOAD_ACTION_NAME)\n      .subscribe((token: string) => {\n        this.cs.setInvisibelCaptcha(token);\n        if (!maxSizeReached) {\n          const formData: FormData = new FormData();\n          for (var i = 0; i < event.target.files.length; i++) {\n            formData.append(\"files\", event.target.files[i], event.target.files[i].name);\n          }\n          let files = [...event.target.files];\n          event.target.value = '';\n          if(!this.uploadToDMS){\n            // let files = [...event.target.files];\n              for (var i = 0; i < files.length; i++) {\n                // this.queue.push(files[i]);\n                this.mapOfFiles.set(files[i], null);\n              }\n            this.files.emit(this.mapOfFiles)\n            return;\n          }\n          this.fs\n            .uploadFile(formData)\n            .subscribe(\n              res => {\n                for (var i = 0; i < files.length; i++) {\n                  this.queue.push(files[i]);\n                  this.mapOfFiles.set(files[i], res[i].fileId);\n                }\n                this.onChange(Array.from(this.mapOfFiles.values()));\n                this.success('File(s) uploaded successfully.');\n\t\t                //Specifically for Signature-Upload (Will be move to a new method)\n                const file = (this.mapOfFiles.entries().next().value)[0];\n                if (file && (file.type === 'image/png' || file.type === 'image/jpeg' \n                  || file.type === 'image/gif')) {\n                  const reader = new FileReader();\n                  reader.onload = (e: any) => {\n                    this.imageBase64 = e.target.result;\n                    this.imageHtml = `<img src=\"${this.imageBase64}\" alt=\"Uploaded Image\" width=\"125\" height=\"75\">`;\n                  };\n                  reader.readAsDataURL(file);\n                }\n                //\n                this.showProgress = false;\n                this.upload.emit(Array.from(this.mapOfFiles.values()));\n                this.files.emit(this.mapOfFiles);\n              },\n              err => {\n                this.showProgress = false;\n                this.error(\"File upload failed. Please try again.\");\n                console.log(err);\n              });\n        }\n      }, err => {\n        this.showProgress = true;\n        this.error(\"File upload failed. Please try again.\");\n        console.log(err);\n      });\n  }\n\n  removeFromQueue(fileToRemove) {\n    let index;\n    for (var i = 0; i < this.queue.length; i++) {\n      if (this.queue[i].name === fileToRemove.name) {\n        index = i;\n      }\n    }\n    this.showProgress = true;\n    let fileId = this.mapOfFiles.get(fileToRemove);\n    this.cs.generateCaptchaToken(this.FILE_UPLOAD_ACTION_NAME)\n      .subscribe((token: string) => {\n        this.cs.setInvisibelCaptcha(token);\n        this.fs.deleteFile(fileId)\n          .subscribe(res => {\n            this.queue.splice(index, 1);\n            this.mapOfFiles.delete(fileToRemove);\n            this.showProgress = false;\n            this.onChange(Array.from(this.mapOfFiles.values()));\n            this.upload.emit(Array.from(this.mapOfFiles.values()))\n            this.files.emit(this.mapOfFiles);\n          }, err => {\n            this.showProgress = false;\n            this.error(\"Error while deleting file. Please try again.\");\n            console.log(err);\n          })\n      }, err => {\n        this.showProgress = false;\n        this.error(\"Error while deleting file. Please try again.\");\n        console.log(err);\n      });\n\n  }\n\n  getSizeInMB(num: number) {\n    return num / 1024 / 1024\n  }\n\n  async presentToast(msg, color) {\n    const toast = await this.toastController.create({\n      message: msg,\n      duration: 5000,\n      color: color,\n      position: 'bottom'\n    });\n    toast.present();\n  }\n\n  success(msg) {\n    this.presentToast(msg, 'primary');\n  }\n\n  error(msg) {\n    this.presentToast(msg, 'danger');\n  }\n\n}\n","<form [formGroup]=\"uploadFileForm\" #uploadFileFormDirective=\"ngForm\">\r\n  <section *ngIf=\"this.context != 'signature' && this.context !='uploadZipCodes'\">\r\n  <p-table [value]=\"queue\" responsiveLayout=\"scroll\" [loading]=\"showProgress\">\r\n    <ng-template pTemplate=\"header\">\r\n      <tr>\r\n        <th>Name</th>\r\n        <th>Size</th>\r\n        <th style=\"text-align:right\" *ngIf=\"proofOfAnything\">\r\n          <app-overlay-info overlayText=\"{{'proof.of.anything.info'| translate}}\"\r\n          style=\"margin-top: 2px; margin-left: 6px;\"></app-overlay-info>\r\n        </th>\r\n        <th class=\"ion-text-right\">\r\n          <div class=\"file-input-container\" *ngIf=\"multiple && !proofOfAnything\">\r\n            <input type=\"file\" #fileInput formControlName=\"uploadFileCtrl\" [accept]=\"allowedFileType\"\r\n              multiple=\"multiple\" (change)=\"addToQueue($event)\" />\r\n            <ion-button shape=\"round\" size=\"small\" type=\"submit\" fill=\"outline\" (click)=\"fileInput.click()\">\r\n              Choose Files\r\n            </ion-button>\r\n          </div>\r\n\r\n          <div class=\"file-input-container\" *ngIf=\"!multiple && !proofOfAnything\">\r\n            <input type=\"file\" #fileInput formControlName=\"uploadFileCtrl\" [accept]=\"allowedFileType\"\r\n              (change)=\"addToQueue($event)\" />\r\n            <ion-button shape=\"round\" size=\"small\" type=\"submit\" fill=\"outline\" (click)=\"fileInput.click()\">\r\n              Choose File\r\n            </ion-button>\r\n          </div>\r\n        </th>\r\n      </tr>\r\n    </ng-template>\r\n    <ng-template pTemplate=\"body\" let-queue>\r\n      <tr>\r\n        <td>{{ queue?.name }}</td>\r\n        <td>{{ queue?.size/1024/1024 | number:'.2' }} MB</td>\r\n        <td class=\"ion-text-right\">\r\n          <ion-button shape=\"round\" size=\"small\" pTooltip=\"Remove\" (click)=\"removeFromQueue(queue)\"\r\n            tooltipPosition=\"bottom\" class=\"ion-padding-left\">\r\n            <ion-icon name=\"trash-outline\"></ion-icon>\r\n          </ion-button>\r\n        </td>\r\n      </tr>\r\n    </ng-template>\r\n    <ng-template pTemplate=\"emptymessage\">\r\n      <tr *ngIf=\"!proofOfAnything\">\r\n        <td [attr.colspan]=\"3\">\r\n            <ul>\r\n              <li *ngIf=\"allowedFileType\">You are allowed to upload file(s) with following extentions: {{allowedFileType}}.</li>\r\n              <li>Total file(s) size cannot exceed <b>{{maxSizeInMB}}</b> MB.</li>\r\n              <li>You can upload maximum <b>{{noOfFilesToUpload}}</b> file(s).</li>\r\n            </ul>\r\n        </td>\r\n      </tr>\r\n    </ng-template>\r\n    <ng-template pTemplate=\"footer\"> \r\n      <tr *ngIf=\"proofOfAnything\">\r\n        <td *ngIf=\"queue.length == 0\">\r\n          <div><b>+ Add</b> files</div>\r\n        </td>\r\n        <td *ngIf=\"queue.length > 0\">\r\n          <div><b>+ Add</b> any other files</div>\r\n        </td>\r\n        <td></td>\r\n        <td class=\"file-input-container\">\r\n            <input type=\"file\" #fileInput formControlName=\"uploadFileCtrl\" [accept]=\"allowedFileType\"\r\n              (change)=\"addToQueue($event)\" />\r\n            <ion-button aria-label=\"Add Files\" (click)=\"fileInput.click()\" fill=\"outline\" size=\"small\" class=\"action-button\">\r\n              <fa-icon [icon]=\"['fal', 'plus']\" class=\"action-icon\"></fa-icon>\r\n            </ion-button>\r\n        </td>\r\n      </tr>\r\n    </ng-template>\r\n  </p-table>\r\n</section>\r\n<section *ngIf=\"this.context == 'signature'\">\r\n  <ion-row>\r\n    <ion-col>\r\n      <div [innerHTML]=\"imageHtml\" style=\"width: 385px; height: 100px; border: 1px solid gray; justify-content: center; align-items: center;\"></div>\r\n    </ion-col>\r\n    <ion-col>\r\n      <div class=\"file-input-container\">\r\n        <input type=\"file\" #fileInput formControlName=\"uploadFileCtrl\" [accept]=\"allowedFileType\"\r\n          (change)=\"uploadToTaxAudit($event)\" />\r\n        <ion-button shape=\"square\" size=\"small\" type=\"submit\" fill=\"outline\" (click)=\"fileInput.click()\">\r\n          Import\r\n        </ion-button>\r\n      </div>\r\n    </ion-col>\r\n  </ion-row>\r\n</section>\r\n<section *ngIf=\"this.context == 'uploadZipCodes'\">\r\n  <div class=\"upload-input-container\">\r\n    <input type=\"file\" #fileInput formControlName=\"uploadFileCtrl\" [accept]=\"allowedFileType\"\r\n      (change)=\"addToQueue($event)\" />\r\n    <ion-button shape=\"square\" size=\"default\" type=\"submit\" fill=\"outline\" (click)=\"fileInput.click()\">\r\n      Upload Zip Codes\r\n    </ion-button>\r\n  </div>\r\n</section>\r\n</form>"]}
|