@seniorsistemas/angular-components 17.3.16 → 17.3.17
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/bundles/seniorsistemas-angular-components.umd.js +132 -94
- package/bundles/seniorsistemas-angular-components.umd.js.map +1 -1
- package/bundles/seniorsistemas-angular-components.umd.min.js +2 -2
- package/bundles/seniorsistemas-angular-components.umd.min.js.map +1 -1
- package/components/file-upload/components/file-item/file-item.component.d.ts +7 -1
- package/components/file-upload/file-upload.component.d.ts +4 -2
- package/components/file-upload/models/validate-errors.d.ts +1 -0
- package/esm2015/components/file-upload/components/file-item/file-item.component.js +23 -6
- package/esm2015/components/file-upload/file-upload.component.js +23 -7
- package/esm2015/components/file-upload/file-upload.module.js +8 -2
- package/esm2015/components/file-upload/models/validate-errors.js +2 -1
- package/esm2015/seniorsistemas-angular-components.js +62 -61
- package/esm5/components/file-upload/components/file-item/file-item.component.js +24 -6
- package/esm5/components/file-upload/file-upload.component.js +24 -8
- package/esm5/components/file-upload/file-upload.module.js +8 -2
- package/esm5/components/file-upload/models/validate-errors.js +2 -1
- package/esm5/seniorsistemas-angular-components.js +62 -61
- package/fesm2015/seniorsistemas-angular-components.js +73 -37
- package/fesm2015/seniorsistemas-angular-components.js.map +1 -1
- package/fesm5/seniorsistemas-angular-components.js +74 -37
- package/fesm5/seniorsistemas-angular-components.js.map +1 -1
- package/package.json +1 -1
- package/seniorsistemas-angular-components.d.ts +61 -60
- package/seniorsistemas-angular-components.metadata.json +1 -1
|
@@ -1,6 +1,8 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { AfterContentInit, EventEmitter } from "@angular/core";
|
|
2
|
+
import { LocaleService } from "../../../locale";
|
|
2
3
|
import { FileDto } from "../../models";
|
|
3
4
|
export declare class FileItemComponent implements AfterContentInit {
|
|
5
|
+
private readonly localeService;
|
|
4
6
|
id: string;
|
|
5
7
|
file: FileDto;
|
|
6
8
|
canReadFiles: boolean;
|
|
@@ -12,9 +14,13 @@ export declare class FileItemComponent implements AfterContentInit {
|
|
|
12
14
|
ariaLabelSuccess: string;
|
|
13
15
|
cancelUpload: EventEmitter<FileDto>;
|
|
14
16
|
removeFile: EventEmitter<FileDto>;
|
|
17
|
+
private _locale;
|
|
18
|
+
constructor(localeService: LocaleService);
|
|
19
|
+
ngOnInit(): void;
|
|
15
20
|
ngAfterContentInit(): void;
|
|
16
21
|
onResize(): void;
|
|
17
22
|
isSmallDevice: boolean;
|
|
18
23
|
private _update;
|
|
19
24
|
simplifySize(size: number): string;
|
|
25
|
+
private _getLocale;
|
|
20
26
|
}
|
|
@@ -26,6 +26,7 @@ export declare class FileUploadComponent implements OnInit, OnDestroy {
|
|
|
26
26
|
supportedExtensions: string[];
|
|
27
27
|
ariaLabelFileName: string;
|
|
28
28
|
maxFileSize: number;
|
|
29
|
+
maxCombinedFileSize: number;
|
|
29
30
|
fileLimit: number;
|
|
30
31
|
ariaLabelProgress: string;
|
|
31
32
|
ariaLabelSuccess: string;
|
|
@@ -48,10 +49,10 @@ export declare class FileUploadComponent implements OnInit, OnDestroy {
|
|
|
48
49
|
anchor: ElementRef;
|
|
49
50
|
}>;
|
|
50
51
|
validateErrors: EventEmitter<UploadError>;
|
|
51
|
-
private _files;
|
|
52
|
-
private readonly ngUsubscribe;
|
|
53
52
|
inputValue: string;
|
|
54
53
|
modifiedDate: string;
|
|
54
|
+
private _files;
|
|
55
|
+
private readonly ngUsubscribe;
|
|
55
56
|
constructor(sanitizer: DomSanitizer, fileUploadService: FileUploadService, translate: TranslateService);
|
|
56
57
|
ngOnInit(): void;
|
|
57
58
|
ngOnDestroy(): void;
|
|
@@ -62,6 +63,7 @@ export declare class FileUploadComponent implements OnInit, OnDestroy {
|
|
|
62
63
|
get files(): FileDto[];
|
|
63
64
|
private _isImage;
|
|
64
65
|
private _isFileLimitExceeded;
|
|
66
|
+
private _isFileCombinedSizeExceeded;
|
|
65
67
|
private _isFileSizeExceeded;
|
|
66
68
|
private _isUnsupportedFileExtension;
|
|
67
69
|
private _clearFileInput;
|
|
@@ -1,14 +1,20 @@
|
|
|
1
1
|
import { __decorate } from "tslib";
|
|
2
|
-
import { Component,
|
|
3
|
-
import {
|
|
2
|
+
import { Component, EventEmitter, HostListener, Input, Output } from "@angular/core";
|
|
3
|
+
import { first } from "rxjs/operators";
|
|
4
|
+
import { LocaleService } from "../../../locale";
|
|
4
5
|
import { Breakpoints } from "../../../utils";
|
|
6
|
+
import { StorageUnits } from "../../models";
|
|
5
7
|
let FileItemComponent = class FileItemComponent {
|
|
6
|
-
constructor() {
|
|
8
|
+
constructor(localeService) {
|
|
9
|
+
this.localeService = localeService;
|
|
7
10
|
this.canReadFiles = true;
|
|
8
11
|
this.canRemoveFiles = true;
|
|
9
12
|
this.cancelUpload = new EventEmitter();
|
|
10
13
|
this.removeFile = new EventEmitter();
|
|
11
14
|
}
|
|
15
|
+
ngOnInit() {
|
|
16
|
+
this._getLocale();
|
|
17
|
+
}
|
|
12
18
|
ngAfterContentInit() {
|
|
13
19
|
this._update();
|
|
14
20
|
}
|
|
@@ -38,9 +44,20 @@ let FileItemComponent = class FileItemComponent {
|
|
|
38
44
|
convertedSize = size / StorageUnits.GB;
|
|
39
45
|
unit = "GB";
|
|
40
46
|
}
|
|
41
|
-
return `${convertedSize} ${unit}`;
|
|
47
|
+
return `${convertedSize.toLocaleString(this._locale, { maximumFractionDigits: 2 })} ${unit}`;
|
|
48
|
+
}
|
|
49
|
+
_getLocale() {
|
|
50
|
+
this.localeService
|
|
51
|
+
.getLocale()
|
|
52
|
+
.pipe(first())
|
|
53
|
+
.subscribe((locale) => {
|
|
54
|
+
this._locale = locale;
|
|
55
|
+
});
|
|
42
56
|
}
|
|
43
57
|
};
|
|
58
|
+
FileItemComponent.ctorParameters = () => [
|
|
59
|
+
{ type: LocaleService }
|
|
60
|
+
];
|
|
44
61
|
__decorate([
|
|
45
62
|
Input()
|
|
46
63
|
], FileItemComponent.prototype, "id", void 0);
|
|
@@ -81,8 +98,8 @@ FileItemComponent = __decorate([
|
|
|
81
98
|
Component({
|
|
82
99
|
selector: "s-file-item",
|
|
83
100
|
template: "<div [id]=\"id\" class=\"file-item-container\">\n <div class=\"file-info\">\n <ng-container *ngIf=\"canReadFiles; then fileNameUrl; else fileName\"></ng-container>\n <ng-template #fileNameUrl>\n <a\n class=\"file-name file-name--link\"\n tabindex=\"0\"\n [href]=\"file.objectURL\"\n download>\n {{ file.name }}\n </a>\n </ng-template>\n <ng-template #fileName>\n <span\n *ngIf=\"!canReadFiles\"\n class=\"file-name\">\n {{ file.name }}\n </span>\n </ng-template>\n <span class=\"file-size\">\n {{ simplifySize(file.size) }}\n </span>\n <div\n *ngIf=\"file.isUploading && !isSmallDevice\"\n class=\"progressbar\"\n [attr.aria-label]=\"ariaLabelProgress || 'platform.angular_components.loading_file' | translate\">\n <s-progressbar\n [value]=\"file.progress\"\n activeColor=\"blue\"\n [showValue]=\"true\">\n </s-progressbar>\n </div>\n <span\n *ngIf=\"file.isUploading && isSmallDevice\" \n class=\"fas fa-circle-notch fa-spin\"\n [attr.aria-label]=\"ariaLabelProgress || 'platform.angular_components.loading_file' | translate\">\n </span>\n\n <span\n *ngIf=\"!file.isUploading && !file.error\"\n class=\"status-icon status-icon--success fas fa-check\"\n [attr.aria-label]=\"ariaLabelSuccess || successTooltip || 'platform.angular_components.file_attached_successfully' | translate\"\n [sTooltip]=\"successTooltip || 'platform.angular_components.file_attached_successfully' | translate\">\n </span>\n <span\n *ngIf=\"!file.isUploading && file.error\"\n class=\"status-icon status-icon--fail fas fa-times\"\n [attr.aria-label]=\"file.error?.message\"\n [sTooltip]=\"file.error?.message\">\n </span>\n </div>\n <button\n *ngIf=\"file.isUploading\"\n class=\"file-option file-option--cancel\"\n (click)=\"cancelUpload.emit(file)\">\n {{ cancelLabel || \"platform.angular_components.cancel\" | translate }}\n </button>\n <button\n *ngIf=\"canRemoveFiles && !file.isUploading\"\n class=\"file-option file-option--remove\"\n (click)=\"removeFile.emit(file)\">\n {{ removeLabel || \"platform.angular_components.remove\" | translate }}\n </button>\n</div>\n",
|
|
84
|
-
styles: [".file-item-container{-ms-flex-align:center;align-items:center;display:-ms-flexbox;display:flex;gap:16px;padding:16px}.file-item-container .file-info{color:#212533;display:-ms-flexbox;display:flex;font-family:\"Open Sans\",sans-serif;font-size:14px;gap:16px;
|
|
101
|
+
styles: [".file-item-container{-ms-flex-align:center;align-items:center;display:-ms-flexbox;display:flex;gap:16px;padding:16px}.file-item-container .file-info{color:#212533;display:-ms-flexbox;display:flex;font-family:\"Open Sans\",sans-serif;font-size:14px;gap:16px;-ms-flex-positive:1;flex-grow:1;-ms-flex-align:center;align-items:center}.file-item-container .file-info .file-name{-ms-flex-positive:1;flex-grow:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-item-container .file-info .file-name--link{color:#428bca;text-decoration:none}.file-item-container .file-info .file-size{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-item-container .progressbar{width:20%}.file-item-container .status-icon{-ms-flex-align:center;align-items:center;display:-ms-flexbox;display:flex;font-size:12px}.file-item-container .status-icon--success{color:#0c9348}.file-item-container .status-icon--fail{color:#c13018}.file-item-container .file-option{background-color:transparent;border:none;color:#428bca;cursor:pointer;font-family:\"Open Sans\",sans-serif;font-size:14px;overflow:hidden;text-overflow:ellipsis;max-width:100%}@media screen and (max-width:600px){.file-item-container{-ms-flex-align:start;align-items:flex-start;-ms-flex-direction:column;flex-direction:column}}"]
|
|
85
102
|
})
|
|
86
103
|
], FileItemComponent);
|
|
87
104
|
export { FileItemComponent };
|
|
88
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
105
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS1pdGVtLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0BzZW5pb3JzaXN0ZW1hcy9hbmd1bGFyLWNvbXBvbmVudHMvIiwic291cmNlcyI6WyJjb21wb25lbnRzL2ZpbGUtdXBsb2FkL2NvbXBvbmVudHMvZmlsZS1pdGVtL2ZpbGUtaXRlbS5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBb0IsU0FBUyxFQUFFLFlBQVksRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUV2RyxPQUFPLEVBQUUsS0FBSyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFFdkMsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQ2hELE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUM3QyxPQUFPLEVBQVcsWUFBWSxFQUFFLE1BQU0sY0FBYyxDQUFDO0FBT3JELElBQWEsaUJBQWlCLEdBQTlCLE1BQWEsaUJBQWlCO0lBb0MxQixZQUE2QixhQUE0QjtRQUE1QixrQkFBYSxHQUFiLGFBQWEsQ0FBZTtRQTVCbEQsaUJBQVksR0FBRyxJQUFJLENBQUM7UUFHcEIsbUJBQWMsR0FBRyxJQUFJLENBQUM7UUFrQnRCLGlCQUFZLEdBQUcsSUFBSSxZQUFZLEVBQVcsQ0FBQztRQUczQyxlQUFVLEdBQUcsSUFBSSxZQUFZLEVBQVcsQ0FBQztJQUlZLENBQUM7SUFFdEQsUUFBUTtRQUNYLElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQztJQUN0QixDQUFDO0lBRU0sa0JBQWtCO1FBQ3JCLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQztJQUNuQixDQUFDO0lBR00sUUFBUTtRQUNYLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQztJQUNuQixDQUFDO0lBSU8sT0FBTztRQUNYLE1BQU0sV0FBVyxHQUFHLE1BQU0sQ0FBQyxVQUFVLENBQUM7UUFDdEMsSUFBSSxDQUFDLGFBQWEsR0FBRyxXQUFXLElBQUksV0FBVyxDQUFDLE1BQU0sQ0FBQztJQUMzRCxDQUFDO0lBRU0sWUFBWSxDQUFDLElBQVk7UUFDNUIsSUFBSSxJQUFZLENBQUM7UUFDakIsSUFBSSxhQUFxQixDQUFDO1FBRTFCLElBQUksSUFBSSxHQUFHLFlBQVksQ0FBQyxFQUFFLEVBQUU7WUFDeEIsYUFBYSxHQUFHLElBQUksQ0FBQztZQUNyQixJQUFJLEdBQUcsT0FBTyxDQUFDO1NBQ2xCO2FBQU0sSUFBSSxJQUFJLEdBQUcsWUFBWSxDQUFDLEVBQUUsRUFBRTtZQUMvQixhQUFhLEdBQUcsSUFBSSxHQUFHLFlBQVksQ0FBQyxFQUFFLENBQUM7WUFDdkMsSUFBSSxHQUFHLElBQUksQ0FBQztTQUNmO2FBQU0sSUFBSSxJQUFJLEdBQUcsWUFBWSxDQUFDLEVBQUUsRUFBRTtZQUMvQixhQUFhLEdBQUcsSUFBSSxHQUFHLFlBQVksQ0FBQyxFQUFFLENBQUM7WUFDdkMsSUFBSSxHQUFHLElBQUksQ0FBQztTQUNmO2FBQU07WUFDSCxhQUFhLEdBQUcsSUFBSSxHQUFHLFlBQVksQ0FBQyxFQUFFLENBQUM7WUFDdkMsSUFBSSxHQUFHLElBQUksQ0FBQztTQUNmO1FBRUQsT0FBTyxHQUFHLGFBQWEsQ0FBQyxjQUFjLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRSxFQUFFLHFCQUFxQixFQUFFLENBQUMsRUFBRSxDQUFDLElBQUksSUFBSSxFQUFFLENBQUM7SUFDakcsQ0FBQztJQUVPLFVBQVU7UUFDZCxJQUFJLENBQUMsYUFBYTthQUNiLFNBQVMsRUFBRTthQUNYLElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQzthQUNiLFNBQVMsQ0FBQyxDQUFDLE1BQU0sRUFBRSxFQUFFO1lBQ2xCLElBQUksQ0FBQyxPQUFPLEdBQUcsTUFBTSxDQUFDO1FBQzFCLENBQUMsQ0FBQyxDQUFDO0lBQ1gsQ0FBQztDQUNKLENBQUE7O1lBbkQrQyxhQUFhOztBQWxDekQ7SUFEQyxLQUFLLEVBQUU7NkNBQ1U7QUFHbEI7SUFEQyxLQUFLLEVBQUU7K0NBQ2E7QUFHckI7SUFEQyxLQUFLLEVBQUU7dURBQ21CO0FBRzNCO0lBREMsS0FBSyxFQUFFO3lEQUNxQjtBQUc3QjtJQURDLEtBQUssRUFBRTtzREFDbUI7QUFHM0I7SUFEQyxLQUFLLEVBQUU7c0RBQ21CO0FBRzNCO0lBREMsS0FBSyxFQUFFOzREQUN5QjtBQUdqQztJQURDLEtBQUssRUFBRTt5REFDc0I7QUFHOUI7SUFEQyxLQUFLLEVBQUU7MkRBQ3dCO0FBR2hDO0lBREMsTUFBTSxFQUFFO3VEQUN5QztBQUdsRDtJQURDLE1BQU0sRUFBRTtxREFDdUM7QUFlaEQ7SUFEQyxZQUFZLENBQUMsZUFBZSxDQUFDO2lEQUc3QjtBQWpEUSxpQkFBaUI7SUFMN0IsU0FBUyxDQUFDO1FBQ1AsUUFBUSxFQUFFLGFBQWE7UUFDdkIsOGtGQUF5Qzs7S0FFNUMsQ0FBQztHQUNXLGlCQUFpQixDQXVGN0I7U0F2RlksaUJBQWlCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQWZ0ZXJDb250ZW50SW5pdCwgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIEhvc3RMaXN0ZW5lciwgSW5wdXQsIE91dHB1dCB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5cbmltcG9ydCB7IGZpcnN0IH0gZnJvbSBcInJ4anMvb3BlcmF0b3JzXCI7XG5cbmltcG9ydCB7IExvY2FsZVNlcnZpY2UgfSBmcm9tIFwiLi4vLi4vLi4vbG9jYWxlXCI7XG5pbXBvcnQgeyBCcmVha3BvaW50cyB9IGZyb20gXCIuLi8uLi8uLi91dGlsc1wiO1xuaW1wb3J0IHsgRmlsZUR0bywgU3RvcmFnZVVuaXRzIH0gZnJvbSBcIi4uLy4uL21vZGVsc1wiO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogXCJzLWZpbGUtaXRlbVwiLFxuICAgIHRlbXBsYXRlVXJsOiBcIi4vZmlsZS1pdGVtLmNvbXBvbmVudC5odG1sXCIsXG4gICAgc3R5bGVVcmxzOiBbXCIuL2ZpbGUtaXRlbS5jb21wb25lbnQuc2Nzc1wiXSxcbn0pXG5leHBvcnQgY2xhc3MgRmlsZUl0ZW1Db21wb25lbnQgaW1wbGVtZW50cyBBZnRlckNvbnRlbnRJbml0IHtcbiAgICBASW5wdXQoKVxuICAgIHB1YmxpYyBpZDogc3RyaW5nO1xuXG4gICAgQElucHV0KClcbiAgICBwdWJsaWMgZmlsZTogRmlsZUR0bztcblxuICAgIEBJbnB1dCgpXG4gICAgcHVibGljIGNhblJlYWRGaWxlcyA9IHRydWU7XG5cbiAgICBASW5wdXQoKVxuICAgIHB1YmxpYyBjYW5SZW1vdmVGaWxlcyA9IHRydWU7XG5cbiAgICBASW5wdXQoKVxuICAgIHB1YmxpYyBjYW5jZWxMYWJlbDogc3RyaW5nO1xuXG4gICAgQElucHV0KClcbiAgICBwdWJsaWMgcmVtb3ZlTGFiZWw6IHN0cmluZztcblxuICAgIEBJbnB1dCgpXG4gICAgcHVibGljIGFyaWFMYWJlbFByb2dyZXNzOiBzdHJpbmc7XG5cbiAgICBASW5wdXQoKVxuICAgIHB1YmxpYyBzdWNjZXNzVG9vbHRpcDogc3RyaW5nO1xuXG4gICAgQElucHV0KClcbiAgICBwdWJsaWMgYXJpYUxhYmVsU3VjY2Vzczogc3RyaW5nO1xuXG4gICAgQE91dHB1dCgpXG4gICAgcHVibGljIGNhbmNlbFVwbG9hZCA9IG5ldyBFdmVudEVtaXR0ZXI8RmlsZUR0bz4oKTtcblxuICAgIEBPdXRwdXQoKVxuICAgIHB1YmxpYyByZW1vdmVGaWxlID0gbmV3IEV2ZW50RW1pdHRlcjxGaWxlRHRvPigpO1xuXG4gICAgcHJpdmF0ZSBfbG9jYWxlOiBzdHJpbmc7XG5cbiAgICBjb25zdHJ1Y3Rvcihwcml2YXRlIHJlYWRvbmx5IGxvY2FsZVNlcnZpY2U6IExvY2FsZVNlcnZpY2UpIHt9XG5cbiAgICBwdWJsaWMgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgICAgIHRoaXMuX2dldExvY2FsZSgpO1xuICAgIH1cblxuICAgIHB1YmxpYyBuZ0FmdGVyQ29udGVudEluaXQoKTogdm9pZCB7XG4gICAgICAgIHRoaXMuX3VwZGF0ZSgpO1xuICAgIH1cblxuICAgIEBIb3N0TGlzdGVuZXIoXCJ3aW5kb3c6cmVzaXplXCIpXG4gICAgcHVibGljIG9uUmVzaXplKCk6IHZvaWQge1xuICAgICAgICB0aGlzLl91cGRhdGUoKTtcbiAgICB9XG5cbiAgICBwdWJsaWMgaXNTbWFsbERldmljZTogYm9vbGVhbjtcblxuICAgIHByaXZhdGUgX3VwZGF0ZSgpIHtcbiAgICAgICAgY29uc3Qgd2luZG93V2lkdGggPSB3aW5kb3cuaW5uZXJXaWR0aDtcbiAgICAgICAgdGhpcy5pc1NtYWxsRGV2aWNlID0gd2luZG93V2lkdGggPD0gQnJlYWtwb2ludHMuU01fTUFYO1xuICAgIH1cblxuICAgIHB1YmxpYyBzaW1wbGlmeVNpemUoc2l6ZTogbnVtYmVyKTogc3RyaW5nIHtcbiAgICAgICAgbGV0IHVuaXQ6IHN0cmluZztcbiAgICAgICAgbGV0IGNvbnZlcnRlZFNpemU6IG51bWJlcjtcblxuICAgICAgICBpZiAoc2l6ZSA8IFN0b3JhZ2VVbml0cy5LQikge1xuICAgICAgICAgICAgY29udmVydGVkU2l6ZSA9IHNpemU7XG4gICAgICAgICAgICB1bml0ID0gXCJieXRlc1wiO1xuICAgICAgICB9IGVsc2UgaWYgKHNpemUgPCBTdG9yYWdlVW5pdHMuTUIpIHtcbiAgICAgICAgICAgIGNvbnZlcnRlZFNpemUgPSBzaXplIC8gU3RvcmFnZVVuaXRzLktCO1xuICAgICAgICAgICAgdW5pdCA9IFwiS0JcIjtcbiAgICAgICAgfSBlbHNlIGlmIChzaXplIDwgU3RvcmFnZVVuaXRzLkdCKSB7XG4gICAgICAgICAgICBjb252ZXJ0ZWRTaXplID0gc2l6ZSAvIFN0b3JhZ2VVbml0cy5NQjtcbiAgICAgICAgICAgIHVuaXQgPSBcIk1CXCI7XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICBjb252ZXJ0ZWRTaXplID0gc2l6ZSAvIFN0b3JhZ2VVbml0cy5HQjtcbiAgICAgICAgICAgIHVuaXQgPSBcIkdCXCI7XG4gICAgICAgIH1cblxuICAgICAgICByZXR1cm4gYCR7Y29udmVydGVkU2l6ZS50b0xvY2FsZVN0cmluZyh0aGlzLl9sb2NhbGUsIHsgbWF4aW11bUZyYWN0aW9uRGlnaXRzOiAyIH0pfSAke3VuaXR9YDtcbiAgICB9XG5cbiAgICBwcml2YXRlIF9nZXRMb2NhbGUoKTogdm9pZCB7XG4gICAgICAgIHRoaXMubG9jYWxlU2VydmljZVxuICAgICAgICAgICAgLmdldExvY2FsZSgpXG4gICAgICAgICAgICAucGlwZShmaXJzdCgpKVxuICAgICAgICAgICAgLnN1YnNjcmliZSgobG9jYWxlKSA9PiB7XG4gICAgICAgICAgICAgICAgdGhpcy5fbG9jYWxlID0gbG9jYWxlO1xuICAgICAgICAgICAgfSk7XG4gICAgfVxufVxuIl19
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
var FileUploadComponent_1;
|
|
2
2
|
import { __decorate } from "tslib";
|
|
3
|
-
import { Component, EventEmitter, Input, Output, ViewChild
|
|
3
|
+
import { Component, EventEmitter, Input, Output, ViewChild } from "@angular/core";
|
|
4
4
|
import { DomSanitizer } from "@angular/platform-browser";
|
|
5
5
|
import { TranslateService } from "@ngx-translate/core";
|
|
6
6
|
import { Subject } from "rxjs";
|
|
@@ -27,9 +27,9 @@ let FileUploadComponent = FileUploadComponent_1 = class FileUploadComponent {
|
|
|
27
27
|
this.cancelUpload = new EventEmitter();
|
|
28
28
|
this.downloadFile = new EventEmitter();
|
|
29
29
|
this.validateErrors = new EventEmitter();
|
|
30
|
+
this.inputValue = "";
|
|
30
31
|
this._files = [];
|
|
31
32
|
this.ngUsubscribe = new Subject();
|
|
32
|
-
this.inputValue = "";
|
|
33
33
|
}
|
|
34
34
|
set files(files) {
|
|
35
35
|
var _a;
|
|
@@ -44,10 +44,7 @@ let FileUploadComponent = FileUploadComponent_1 = class FileUploadComponent {
|
|
|
44
44
|
});
|
|
45
45
|
}
|
|
46
46
|
ngOnInit() {
|
|
47
|
-
this.supportedExtensions = this.supportedExtensions
|
|
48
|
-
.map((extension) => extension
|
|
49
|
-
.replace(".", "")
|
|
50
|
-
.toLowerCase());
|
|
47
|
+
this.supportedExtensions = this.supportedExtensions.map((extension) => extension.replace(".", "").toLowerCase());
|
|
51
48
|
}
|
|
52
49
|
ngOnDestroy() {
|
|
53
50
|
this.ngUsubscribe.next();
|
|
@@ -66,6 +63,14 @@ let FileUploadComponent = FileUploadComponent_1 = class FileUploadComponent {
|
|
|
66
63
|
this._clearFileInput();
|
|
67
64
|
return;
|
|
68
65
|
}
|
|
66
|
+
if (this._isFileCombinedSizeExceeded(files)) {
|
|
67
|
+
this.validateErrors.emit({
|
|
68
|
+
files,
|
|
69
|
+
validation: ValidateErrors.MAX_COMBINED_FILE_SIZE,
|
|
70
|
+
});
|
|
71
|
+
this._clearFileInput();
|
|
72
|
+
return;
|
|
73
|
+
}
|
|
69
74
|
for (const file of files) {
|
|
70
75
|
if (this._isUnsupportedFileExtension(file)) {
|
|
71
76
|
this.validateErrors.emit({
|
|
@@ -124,6 +129,14 @@ let FileUploadComponent = FileUploadComponent_1 = class FileUploadComponent {
|
|
|
124
129
|
}
|
|
125
130
|
return this.files.length + files.length > this.fileLimit;
|
|
126
131
|
}
|
|
132
|
+
_isFileCombinedSizeExceeded(files) {
|
|
133
|
+
if (!this.maxCombinedFileSize) {
|
|
134
|
+
return false;
|
|
135
|
+
}
|
|
136
|
+
const filesList = [...files, ...this.files];
|
|
137
|
+
const combinedSize = filesList.reduce((combinedSize, file) => combinedSize + file.size, 0);
|
|
138
|
+
return combinedSize > this.maxCombinedFileSize;
|
|
139
|
+
}
|
|
127
140
|
_isFileSizeExceeded(file) {
|
|
128
141
|
if (!this.maxFileSize) {
|
|
129
142
|
return false;
|
|
@@ -209,6 +222,9 @@ __decorate([
|
|
|
209
222
|
__decorate([
|
|
210
223
|
Input()
|
|
211
224
|
], FileUploadComponent.prototype, "maxFileSize", void 0);
|
|
225
|
+
__decorate([
|
|
226
|
+
Input()
|
|
227
|
+
], FileUploadComponent.prototype, "maxCombinedFileSize", void 0);
|
|
212
228
|
__decorate([
|
|
213
229
|
Input()
|
|
214
230
|
], FileUploadComponent.prototype, "fileLimit", void 0);
|
|
@@ -262,4 +278,4 @@ FileUploadComponent = FileUploadComponent_1 = __decorate([
|
|
|
262
278
|
})
|
|
263
279
|
], FileUploadComponent);
|
|
264
280
|
export { FileUploadComponent };
|
|
265
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-upload.component.js","sourceRoot":"ng://@seniorsistemas/angular-components/","sources":["components/file-upload/file-upload.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    ElementRef,\n    EventEmitter,\n    Input,\n    OnDestroy,\n    OnInit,\n    Output,\n    ViewChild,\n} from \"@angular/core\";\nimport { FormControl } from \"@angular/forms\";\nimport { DomSanitizer } from \"@angular/platform-browser\";\n\nimport { TranslateService } from \"@ngx-translate/core\";\nimport { Subject } from \"rxjs\";\nimport * as moment_ from \"moment\";\n\nimport { Breakpoints } from \"../utils\";\nimport { FileUploadService } from \"./file-upload.service\";\nimport { FileDto } from \"./models/file-dto\";\nimport { ALL_PERMISSIONS, FileUploadPermissions } from \"./models/file-upload-permissions\";\nimport { UploadError } from \"./models/uploadError\";\nimport { ValidateErrors } from \"./models/validate-errors\";\nimport { ListBlobMetadataResponse } from \"./models/list-blob-metadata\";\n\nconst moment = moment_;\n\n@Component({\n    selector: \"s-file-upload\",\n    templateUrl: \"./file-upload.component.html\",\n    styleUrls: [\"./file-upload.component.scss\"],\n})\nexport class FileUploadComponent implements OnInit, OnDestroy {\n    public static nextId = 0;\n\n    public ADD_PERMISSION = FileUploadPermissions.Add;\n    public READ_PERMISSION = FileUploadPermissions.Read;\n    public REMOVE_PERMISSION = FileUploadPermissions.Remove;\n\n    @ViewChild(\"inputUpload\", { static: false })\n    private readonly inputUpload: ElementRef;\n\n    @ViewChild(\"anchor\", { static: false })\n    private readonly anchor: ElementRef;\n\n    @Input()\n    public id = `s-file-upload-${FileUploadComponent.nextId++}`;\n\n    @Input()\n    public chooseLabel: string;\n\n    @Input()\n    public removeLabel: string;\n\n    @Input()\n    public cancelLabel: string;\n\n    @Input()\n    public successTooltip: string;\n\n    @Input()\n    public multiple: boolean;\n\n    @Input()\n    public accept: string;\n\n    @Input()\n    public supportedExtensions: string[] = [];\n\n    @Input()\n    public ariaLabelFileName: string;\n\n    @Input()\n    public maxFileSize: number;\n\n    @Input()\n    public fileLimit: number;\n\n    @Input()\n    public ariaLabelProgress: string;\n\n    @Input()\n    public ariaLabelSuccess: string;\n\n    @Input()\n    public ariaLabelError: string;\n\n    @Input()\n    public ariaLabelRemove: string;\n\n    @Input()\n    public formGroup: FormControl;\n\n    @Input()\n    public disabled = false;\n\n    @Input()\n    public showFileUploadDate: boolean = false;\n\n    @Input()\n    public permissions: FileUploadPermissions[] = ALL_PERMISSIONS;\n\n    @Input()\n    public set files(files: FileDto[]) {\n        if (this.showFileUploadDate && files[0]?.objectId) {\n            this._getUploadDate(files);\n        }\n        this._files = files.map((file) => {\n            if (this._isImage(file)) {\n                file.objectURL = this.sanitizer.bypassSecurityTrustUrl(window.URL.createObjectURL(file));\n            }\n            return file;\n        });\n    }\n\n    @Output()\n    public uploadHandler: EventEmitter<{ files: FileDto[] }> = new EventEmitter();\n\n    @Output()\n    public removeFile: EventEmitter<{ file: File }> = new EventEmitter();\n\n    @Output()\n    public cancelUpload: EventEmitter<number> = new EventEmitter();\n\n    @Output()\n    public downloadFile: EventEmitter<{ index: number; anchor: ElementRef }> = new EventEmitter();\n\n    @Output()\n    public validateErrors: EventEmitter<UploadError> = new EventEmitter();\n\n    private _files: FileDto[] = [];\n    private readonly ngUsubscribe: Subject<void> = new Subject();\n    \n    public inputValue = \"\";\n    public modifiedDate: string;\n\n    constructor(\n        private readonly sanitizer: DomSanitizer,\n        private readonly fileUploadService: FileUploadService,\n        private readonly translate: TranslateService\n    ) {}\n\n    public ngOnInit(): void {\n        this.supportedExtensions = this.supportedExtensions\n            .map((extension) => extension\n            .replace(\".\", \"\")\n            .toLowerCase());\n    }\n\n    public ngOnDestroy(): void {\n        this.ngUsubscribe.next();\n        this.ngUsubscribe.complete();\n    }\n\n    public onFileSelect(files: FileDto[]): void {\n        const newFiles: FileDto[] = [];\n\n        if (!this.multiple) {\n            this.files = [];\n        }\n\n        if (this._isFileLimitExceeded(files)) {\n            this.validateErrors.emit({\n                files,\n                validation: ValidateErrors.MAX_FILE_LIMIT,\n            });\n            this._clearFileInput();\n            return;\n        }\n\n        for (const file of files) {\n            if (this._isUnsupportedFileExtension(file)) {\n                this.validateErrors.emit({\n                    files: [file],\n                    validation: ValidateErrors.UNSUPPORTED_EXTENSION,\n                });\n                continue;\n            }\n\n            if (this._isFileSizeExceeded(file)) {\n                this.validateErrors.emit({\n                    files: [file],\n                    validation: ValidateErrors.MAX_FILE_SIZE,\n                });\n                continue;\n            }\n\n            newFiles.push(file);\n        }\n\n        if (newFiles.length) {\n            this.files = this.files.concat(newFiles);\n            this.uploadHandler.emit({\n                files: newFiles,\n            });\n        }\n\n        this._clearFileInput();\n    }\n\n    public onRemoveFile(file: FileDto): void {\n        const fileIndex = this.files.indexOf(file);\n        const removedFiles = this.files.splice(fileIndex, 1);\n\n        if (removedFiles.length) {\n            this.removeFile.emit({ file });\n        }\n    }\n\n    public onCancelUpload(file: FileDto): void {\n        const index = this.files.indexOf(file);\n\n        if (index != -1) {\n            this.files.splice(index, 1);\n            this.cancelUpload.emit(index);\n        }\n\n        this._clearFileInput();\n    }\n\n    public onDowloadFile(index: number): void {\n        this.downloadFile.emit({\n            index,\n            anchor: this.anchor,\n        });\n    }\n\n    public get files(): FileDto[] {\n        return this._files;\n    }\n\n    private _isImage(file: File): boolean {\n        return /^image\\//.test(file.type);\n    }\n\n    private _isFileLimitExceeded(files: FileDto[]): boolean {\n        if (!this.fileLimit) {\n            return false;\n        }\n        return this.files.length + files.length > this.fileLimit;\n    }\n\n    private _isFileSizeExceeded(file: File): boolean {\n        if (!this.maxFileSize) {\n            return false;\n        }\n        return file.size > this.maxFileSize;\n    }\n\n    private _isUnsupportedFileExtension(file: File): boolean {\n        if (this.supportedExtensions?.length) {\n            const extension = file.name\n                .split(\".\")\n                .pop()\n                .toLowerCase();\n            return !this.supportedExtensions.includes(extension);\n        }\n        return false;\n    }\n\n    private _clearFileInput(): void {\n        this.inputUpload.nativeElement.value = null;\n    }\n\n    private _getUploadDate(blobFile: FileDto[]): void {\n        if (!blobFile) {\n            return;\n        }\n\n        this.fileUploadService\n            .getMetadataCustomField({ objectId: blobFile[0].objectId })\n            .then((metadata) => this._setModifiedDate(metadata));\n    }\n\n    private _setModifiedDate(metadata: ListBlobMetadataResponse): void {\n        const hour = moment(metadata.modified).format(\"HH\");\n        const minutes = moment(metadata.modified).format(\"mm\");\n        const day = moment(metadata.modified).format(\"DD\");\n        const month = moment(metadata.modified).format(\"MM\");\n        const fullYear = moment(metadata.modified).format(\"YYYY\");\n\n        this.modifiedDate = this.translate.instant(\"platform.angular_components.date_modified_custom_blob\", {\n            hour,\n            minutes,\n            day,\n            month,\n            fullYear,\n        });\n    }\n}\n"]}
|
|
281
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-upload.component.js","sourceRoot":"ng://@seniorsistemas/angular-components/","sources":["components/file-upload/file-upload.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EventEmitter, Input, OnDestroy, OnInit, Output, ViewChild } from \"@angular/core\";\nimport { FormControl } from \"@angular/forms\";\nimport { DomSanitizer } from \"@angular/platform-browser\";\n\nimport { TranslateService } from \"@ngx-translate/core\";\nimport { Subject } from \"rxjs\";\nimport * as moment_ from \"moment\";\n\nimport { Breakpoints } from \"../utils\";\nimport { FileUploadService } from \"./file-upload.service\";\nimport { FileDto } from \"./models/file-dto\";\nimport { ALL_PERMISSIONS, FileUploadPermissions } from \"./models/file-upload-permissions\";\nimport { UploadError } from \"./models/uploadError\";\nimport { ValidateErrors } from \"./models/validate-errors\";\nimport { ListBlobMetadataResponse } from \"./models/list-blob-metadata\";\n\nconst moment = moment_;\n\n@Component({\n    selector: \"s-file-upload\",\n    templateUrl: \"./file-upload.component.html\",\n    styleUrls: [\"./file-upload.component.scss\"],\n})\nexport class FileUploadComponent implements OnInit, OnDestroy {\n    public static nextId = 0;\n\n    public ADD_PERMISSION = FileUploadPermissions.Add;\n    public READ_PERMISSION = FileUploadPermissions.Read;\n    public REMOVE_PERMISSION = FileUploadPermissions.Remove;\n\n    @ViewChild(\"inputUpload\", { static: false })\n    private readonly inputUpload: ElementRef;\n\n    @ViewChild(\"anchor\", { static: false })\n    private readonly anchor: ElementRef;\n\n    @Input()\n    public id = `s-file-upload-${FileUploadComponent.nextId++}`;\n\n    @Input()\n    public chooseLabel: string;\n\n    @Input()\n    public removeLabel: string;\n\n    @Input()\n    public cancelLabel: string;\n\n    @Input()\n    public successTooltip: string;\n\n    @Input()\n    public multiple: boolean;\n\n    @Input()\n    public accept: string;\n\n    @Input()\n    public supportedExtensions: string[] = [];\n\n    @Input()\n    public ariaLabelFileName: string;\n\n    @Input()\n    public maxFileSize: number;\n\n    @Input()\n    public maxCombinedFileSize: number;\n\n    @Input()\n    public fileLimit: number;\n\n    @Input()\n    public ariaLabelProgress: string;\n\n    @Input()\n    public ariaLabelSuccess: string;\n\n    @Input()\n    public ariaLabelError: string;\n\n    @Input()\n    public ariaLabelRemove: string;\n\n    @Input()\n    public formGroup: FormControl;\n\n    @Input()\n    public disabled = false;\n\n    @Input()\n    public showFileUploadDate: boolean = false;\n\n    @Input()\n    public permissions: FileUploadPermissions[] = ALL_PERMISSIONS;\n\n    @Input()\n    public set files(files: FileDto[]) {\n        if (this.showFileUploadDate && files[0]?.objectId) {\n            this._getUploadDate(files);\n        }\n        this._files = files.map((file) => {\n            if (this._isImage(file)) {\n                file.objectURL = this.sanitizer.bypassSecurityTrustUrl(window.URL.createObjectURL(file));\n            }\n            return file;\n        });\n    }\n\n    @Output()\n    public uploadHandler: EventEmitter<{ files: FileDto[] }> = new EventEmitter();\n\n    @Output()\n    public removeFile: EventEmitter<{ file: File }> = new EventEmitter();\n\n    @Output()\n    public cancelUpload: EventEmitter<number> = new EventEmitter();\n\n    @Output()\n    public downloadFile: EventEmitter<{ index: number; anchor: ElementRef }> = new EventEmitter();\n\n    @Output()\n    public validateErrors: EventEmitter<UploadError> = new EventEmitter();\n\n    public inputValue = \"\";\n    public modifiedDate: string;\n\n    private _files: FileDto[] = [];\n    private readonly ngUsubscribe: Subject<void> = new Subject();\n\n    constructor(\n        private readonly sanitizer: DomSanitizer,\n        private readonly fileUploadService: FileUploadService,\n        private readonly translate: TranslateService\n    ) {}\n\n    public ngOnInit(): void {\n        this.supportedExtensions = this.supportedExtensions.map((extension) => extension.replace(\".\", \"\").toLowerCase());\n    }\n\n    public ngOnDestroy(): void {\n        this.ngUsubscribe.next();\n        this.ngUsubscribe.complete();\n    }\n\n    public onFileSelect(files: FileDto[]): void {\n        const newFiles: FileDto[] = [];\n\n        if (!this.multiple) {\n            this.files = [];\n        }\n\n        if (this._isFileLimitExceeded(files)) {\n            this.validateErrors.emit({\n                files,\n                validation: ValidateErrors.MAX_FILE_LIMIT,\n            });\n            this._clearFileInput();\n            return;\n        }\n\n        if (this._isFileCombinedSizeExceeded(files)) {\n            this.validateErrors.emit({\n                files,\n                validation: ValidateErrors.MAX_COMBINED_FILE_SIZE,\n            });\n            this._clearFileInput();\n            return;\n        }\n\n        for (const file of files) {\n            if (this._isUnsupportedFileExtension(file)) {\n                this.validateErrors.emit({\n                    files: [file],\n                    validation: ValidateErrors.UNSUPPORTED_EXTENSION,\n                });\n                continue;\n            }\n\n            if (this._isFileSizeExceeded(file)) {\n                this.validateErrors.emit({\n                    files: [file],\n                    validation: ValidateErrors.MAX_FILE_SIZE,\n                });\n                continue;\n            }\n\n            newFiles.push(file);\n        }\n\n        if (newFiles.length) {\n            this.files = this.files.concat(newFiles);\n            this.uploadHandler.emit({\n                files: newFiles,\n            });\n        }\n\n        this._clearFileInput();\n    }\n\n    public onRemoveFile(file: FileDto): void {\n        const fileIndex = this.files.indexOf(file);\n        const removedFiles = this.files.splice(fileIndex, 1);\n\n        if (removedFiles.length) {\n            this.removeFile.emit({ file });\n        }\n    }\n\n    public onCancelUpload(file: FileDto): void {\n        const index = this.files.indexOf(file);\n\n        if (index != -1) {\n            this.files.splice(index, 1);\n            this.cancelUpload.emit(index);\n        }\n\n        this._clearFileInput();\n    }\n\n    public onDowloadFile(index: number): void {\n        this.downloadFile.emit({\n            index,\n            anchor: this.anchor,\n        });\n    }\n\n    public get files(): FileDto[] {\n        return this._files;\n    }\n\n    private _isImage(file: File): boolean {\n        return /^image\\//.test(file.type);\n    }\n\n    private _isFileLimitExceeded(files: FileDto[]): boolean {\n        if (!this.fileLimit) {\n            return false;\n        }\n        return this.files.length + files.length > this.fileLimit;\n    }\n\n    private _isFileCombinedSizeExceeded(files: FileDto[]): boolean {\n        if (!this.maxCombinedFileSize) {\n            return false;\n        }\n\n        const filesList = [...files, ...this.files];\n\n        const combinedSize = filesList.reduce((combinedSize, file) => combinedSize + file.size, 0);\n\n        return combinedSize > this.maxCombinedFileSize;\n    }\n\n    private _isFileSizeExceeded(file: File): boolean {\n        if (!this.maxFileSize) {\n            return false;\n        }\n        return file.size > this.maxFileSize;\n    }\n\n    private _isUnsupportedFileExtension(file: File): boolean {\n        if (this.supportedExtensions?.length) {\n            const extension = file.name\n                .split(\".\")\n                .pop()\n                .toLowerCase();\n            return !this.supportedExtensions.includes(extension);\n        }\n        return false;\n    }\n\n    private _clearFileInput(): void {\n        this.inputUpload.nativeElement.value = null;\n    }\n\n    private _getUploadDate(blobFile: FileDto[]): void {\n        if (!blobFile) {\n            return;\n        }\n\n        this.fileUploadService\n            .getMetadataCustomField({ objectId: blobFile[0].objectId })\n            .then((metadata) => this._setModifiedDate(metadata));\n    }\n\n    private _setModifiedDate(metadata: ListBlobMetadataResponse): void {\n        const hour = moment(metadata.modified).format(\"HH\");\n        const minutes = moment(metadata.modified).format(\"mm\");\n        const day = moment(metadata.modified).format(\"DD\");\n        const month = moment(metadata.modified).format(\"MM\");\n        const fullYear = moment(metadata.modified).format(\"YYYY\");\n\n        this.modifiedDate = this.translate.instant(\"platform.angular_components.date_modified_custom_blob\", {\n            hour,\n            minutes,\n            day,\n            month,\n            fullYear,\n        });\n    }\n}\n"]}
|
|
@@ -1,8 +1,10 @@
|
|
|
1
1
|
import { __decorate } from "tslib";
|
|
2
2
|
import { CommonModule } from "@angular/common";
|
|
3
|
+
import { HttpClientModule } from '@angular/common/http';
|
|
3
4
|
import { NgModule } from "@angular/core";
|
|
4
5
|
import { TranslateModule } from "@ngx-translate/core";
|
|
5
6
|
import { ButtonModule } from "../button/button.module";
|
|
7
|
+
import { LocaleService } from "../locale/locale.service";
|
|
6
8
|
import { ProgressBarModule } from "../progressbar/progressbar.module";
|
|
7
9
|
import { TooltipModule } from "../tooltip/tooltip.module";
|
|
8
10
|
import { FileItemComponent } from "./components/file-item/file-item.component";
|
|
@@ -14,6 +16,7 @@ FileUploadModule = __decorate([
|
|
|
14
16
|
NgModule({
|
|
15
17
|
imports: [
|
|
16
18
|
CommonModule,
|
|
19
|
+
HttpClientModule,
|
|
17
20
|
ButtonModule,
|
|
18
21
|
TooltipModule,
|
|
19
22
|
ProgressBarModule,
|
|
@@ -23,9 +26,12 @@ FileUploadModule = __decorate([
|
|
|
23
26
|
FileUploadComponent,
|
|
24
27
|
FileItemComponent,
|
|
25
28
|
],
|
|
26
|
-
providers: [
|
|
29
|
+
providers: [
|
|
30
|
+
FileUploadService,
|
|
31
|
+
LocaleService,
|
|
32
|
+
],
|
|
27
33
|
exports: [FileUploadComponent],
|
|
28
34
|
})
|
|
29
35
|
], FileUploadModule);
|
|
30
36
|
export { FileUploadModule };
|
|
31
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
37
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS11cGxvYWQubW9kdWxlLmpzIiwic291cmNlUm9vdCI6Im5nOi8vQHNlbmlvcnNpc3RlbWFzL2FuZ3VsYXItY29tcG9uZW50cy8iLCJzb3VyY2VzIjpbImNvbXBvbmVudHMvZmlsZS11cGxvYWQvZmlsZS11cGxvYWQubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDeEQsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUV6QyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFFdEQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUN6RCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQztBQUN0RSxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDMUQsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sNENBQTRDLENBQUM7QUFDL0UsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDOUQsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFxQjFELElBQWEsZ0JBQWdCLEdBQTdCLE1BQWEsZ0JBQWdCO0NBQUcsQ0FBQTtBQUFuQixnQkFBZ0I7SUFuQjVCLFFBQVEsQ0FBQztRQUNOLE9BQU8sRUFBRTtZQUNMLFlBQVk7WUFDWixnQkFBZ0I7WUFDaEIsWUFBWTtZQUNaLGFBQWE7WUFDYixpQkFBaUI7WUFDakIsZUFBZTtTQUNsQjtRQUNELFlBQVksRUFBRTtZQUNWLG1CQUFtQjtZQUNuQixpQkFBaUI7U0FDcEI7UUFDRCxTQUFTLEVBQUU7WUFDUCxpQkFBaUI7WUFDakIsYUFBYTtTQUNoQjtRQUNELE9BQU8sRUFBRSxDQUFDLG1CQUFtQixDQUFDO0tBQ2pDLENBQUM7R0FDVyxnQkFBZ0IsQ0FBRztTQUFuQixnQkFBZ0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29tbW9uXCI7XG5pbXBvcnQgeyBIdHRwQ2xpZW50TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uL2h0dHAnO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuXG5pbXBvcnQgeyBUcmFuc2xhdGVNb2R1bGUgfSBmcm9tIFwiQG5neC10cmFuc2xhdGUvY29yZVwiO1xuXG5pbXBvcnQgeyBCdXR0b25Nb2R1bGUgfSBmcm9tIFwiLi4vYnV0dG9uL2J1dHRvbi5tb2R1bGVcIjtcbmltcG9ydCB7IExvY2FsZVNlcnZpY2UgfSBmcm9tIFwiLi4vbG9jYWxlL2xvY2FsZS5zZXJ2aWNlXCI7XG5pbXBvcnQgeyBQcm9ncmVzc0Jhck1vZHVsZSB9IGZyb20gXCIuLi9wcm9ncmVzc2Jhci9wcm9ncmVzc2Jhci5tb2R1bGVcIjtcbmltcG9ydCB7IFRvb2x0aXBNb2R1bGUgfSBmcm9tIFwiLi4vdG9vbHRpcC90b29sdGlwLm1vZHVsZVwiO1xuaW1wb3J0IHsgRmlsZUl0ZW1Db21wb25lbnQgfSBmcm9tIFwiLi9jb21wb25lbnRzL2ZpbGUtaXRlbS9maWxlLWl0ZW0uY29tcG9uZW50XCI7XG5pbXBvcnQgeyBGaWxlVXBsb2FkQ29tcG9uZW50IH0gZnJvbSBcIi4vZmlsZS11cGxvYWQuY29tcG9uZW50XCI7XG5pbXBvcnQgeyBGaWxlVXBsb2FkU2VydmljZSB9IGZyb20gXCIuL2ZpbGUtdXBsb2FkLnNlcnZpY2VcIjtcblxuQE5nTW9kdWxlKHtcbiAgICBpbXBvcnRzOiBbXG4gICAgICAgIENvbW1vbk1vZHVsZSxcbiAgICAgICAgSHR0cENsaWVudE1vZHVsZSxcbiAgICAgICAgQnV0dG9uTW9kdWxlLFxuICAgICAgICBUb29sdGlwTW9kdWxlLFxuICAgICAgICBQcm9ncmVzc0Jhck1vZHVsZSxcbiAgICAgICAgVHJhbnNsYXRlTW9kdWxlLFxuICAgIF0sXG4gICAgZGVjbGFyYXRpb25zOiBbXG4gICAgICAgIEZpbGVVcGxvYWRDb21wb25lbnQsXG4gICAgICAgIEZpbGVJdGVtQ29tcG9uZW50LFxuICAgIF0sXG4gICAgcHJvdmlkZXJzOiBbXG4gICAgICAgIEZpbGVVcGxvYWRTZXJ2aWNlLFxuICAgICAgICBMb2NhbGVTZXJ2aWNlLFxuICAgIF0sXG4gICAgZXhwb3J0czogW0ZpbGVVcGxvYWRDb21wb25lbnRdLFxufSlcbmV4cG9ydCBjbGFzcyBGaWxlVXBsb2FkTW9kdWxlIHt9XG4iXX0=
|
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
export var ValidateErrors;
|
|
2
2
|
(function (ValidateErrors) {
|
|
3
3
|
ValidateErrors["MAX_FILE_SIZE"] = "MAX_FILE_SIZE";
|
|
4
|
+
ValidateErrors["MAX_COMBINED_FILE_SIZE"] = "MAX_COMBINED_FILE_SIZE";
|
|
4
5
|
ValidateErrors["MAX_FILE_LIMIT"] = "MAX_FILE_LIMIT";
|
|
5
6
|
ValidateErrors["UNSUPPORTED_EXTENSION"] = "UNSUPPORTED_EXTENSION";
|
|
6
7
|
})(ValidateErrors || (ValidateErrors = {}));
|
|
7
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
8
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmFsaWRhdGUtZXJyb3JzLmpzIiwic291cmNlUm9vdCI6Im5nOi8vQHNlbmlvcnNpc3RlbWFzL2FuZ3VsYXItY29tcG9uZW50cy8iLCJzb3VyY2VzIjpbImNvbXBvbmVudHMvZmlsZS11cGxvYWQvbW9kZWxzL3ZhbGlkYXRlLWVycm9ycy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQU4sSUFBWSxjQUtYO0FBTEQsV0FBWSxjQUFjO0lBQ3ZCLGlEQUErQixDQUFBO0lBQy9CLG1FQUFpRCxDQUFBO0lBQ2pELG1EQUFpQyxDQUFBO0lBQ2pDLGlFQUErQyxDQUFBO0FBQ2xELENBQUMsRUFMVyxjQUFjLEtBQWQsY0FBYyxRQUt6QiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBlbnVtIFZhbGlkYXRlRXJyb3JzIHtcbiAgIE1BWF9GSUxFX1NJWkUgPSBcIk1BWF9GSUxFX1NJWkVcIixcbiAgIE1BWF9DT01CSU5FRF9GSUxFX1NJWkUgPSBcIk1BWF9DT01CSU5FRF9GSUxFX1NJWkVcIixcbiAgIE1BWF9GSUxFX0xJTUlUID0gXCJNQVhfRklMRV9MSU1JVFwiLFxuICAgVU5TVVBQT1JURURfRVhURU5TSU9OID0gXCJVTlNVUFBPUlRFRF9FWFRFTlNJT05cIixcbn1cbiJdfQ==
|