ngx-material-entity 15.2.9 → 15.3.1
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/components/edit-page/edit-page.component.d.ts +3 -1
- package/components/input/array/array-table.class.d.ts +3 -1
- package/components/input/file/file-default-input/file-default-input.component.d.ts +0 -2
- package/components/input/file/file-image-input/file-image-input.component.d.ts +3 -2
- package/components/input/file/file-input/file-input.component.d.ts +3 -1
- package/components/input/input.component.d.ts +7 -3
- package/components/input/input.module.d.ts +2 -1
- package/components/table/edit-dialog/edit-entity-dialog.component.d.ts +3 -1
- package/decorators/base/property-decorator.data.d.ts +2 -2
- package/esm2020/components/edit-page/edit-page.component.mjs +16 -13
- package/esm2020/components/input/array/array-table.class.mjs +8 -5
- package/esm2020/components/input/file/file-default-input/file-default-input.component.mjs +1 -6
- package/esm2020/components/input/file/file-image-input/file-image-input.component.mjs +14 -12
- package/esm2020/components/input/file/file-input/file-input.component.mjs +17 -14
- package/esm2020/components/input/input.component.mjs +57 -48
- package/esm2020/components/input/input.module.mjs +8 -4
- package/esm2020/components/table/edit-dialog/edit-entity-dialog.component.mjs +14 -11
- package/esm2020/decorators/base/property-decorator.data.mjs +1 -1
- package/esm2020/services/entity.service.mjs +6 -6
- package/esm2020/utilities/entity.utilities.mjs +21 -12
- package/esm2020/utilities/file.utilities.mjs +15 -11
- package/fesm2015/ngx-material-entity.mjs +169 -147
- package/fesm2015/ngx-material-entity.mjs.map +1 -1
- package/fesm2020/ngx-material-entity.mjs +169 -147
- package/fesm2020/ngx-material-entity.mjs.map +1 -1
- package/package.json +1 -1
- package/utilities/entity.utilities.d.ts +7 -3
- package/utilities/file.utilities.d.ts +6 -2
|
@@ -1,14 +1,9 @@
|
|
|
1
1
|
/* eslint-disable jsdoc/require-jsdoc */
|
|
2
2
|
import { Component } from '@angular/core';
|
|
3
|
-
import { FileUtilities } from '../../../../utilities/file.utilities';
|
|
4
3
|
import { NgxMatEntityBaseInputComponent } from '../../base-input.component';
|
|
5
4
|
import * as i0 from "@angular/core";
|
|
6
5
|
import * as i1 from "../file-input/file-input.component";
|
|
7
6
|
export class FileDefaultInputComponent extends NgxMatEntityBaseInputComponent {
|
|
8
|
-
constructor() {
|
|
9
|
-
super(...arguments);
|
|
10
|
-
this.FileUtilities = FileUtilities;
|
|
11
|
-
}
|
|
12
7
|
async refreshFileData(fileData) {
|
|
13
8
|
this.propertyValue = fileData;
|
|
14
9
|
this.emitChange();
|
|
@@ -20,4 +15,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.3", ngImpor
|
|
|
20
15
|
type: Component,
|
|
21
16
|
args: [{ selector: 'file-default-input', template: "<div [class.file-input]=\"metadata.dragAndDrop\" [class.mat-elevation-z8]=\"metadata.dragAndDrop\">\n <file-input\n (fileDataChangeEvent)=\"refreshFileData($event)\"\n [propertyValue]=\"propertyValue\"\n [metadata]=\"metadata\"\n [getValidationErrorMessage]=\"getValidationErrorMessage\"\n [isReadOnly]=\"isReadOnly\"\n [entity]=\"entity\"\n [key]=\"key\"\n >\n </file-input>\n</div>", styles: [".file-input{margin-top:15px;margin-bottom:15px;padding:15px;border-radius:5px}\n"] }]
|
|
22
17
|
}] });
|
|
23
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS1kZWZhdWx0LWlucHV0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1tYXRlcmlhbC1lbnRpdHkvc3JjL2NvbXBvbmVudHMvaW5wdXQvZmlsZS9maWxlLWRlZmF1bHQtaW5wdXQvZmlsZS1kZWZhdWx0LWlucHV0LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1tYXRlcmlhbC1lbnRpdHkvc3JjL2NvbXBvbmVudHMvaW5wdXQvZmlsZS9maWxlLWRlZmF1bHQtaW5wdXQvZmlsZS1kZWZhdWx0LWlucHV0LmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLHdDQUF3QztBQUN4QyxPQUFPLEVBQUUsU0FBUyxFQUFVLE1BQU0sZUFBZSxDQUFDO0FBSWxELE9BQU8sRUFBRSw4QkFBOEIsRUFBRSxNQUFNLDRCQUE0QixDQUFDOzs7QUFRNUUsTUFBTSxPQUFPLHlCQUNULFNBQVEsOEJBQThGO0lBRXRHLEtBQUssQ0FBQyxlQUFlLENBQUMsUUFBZ0M7UUFDbEQsSUFBSSxDQUFDLGFBQWEsR0FBRyxRQUFRLENBQUM7UUFDOUIsSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFDO0lBQ3RCLENBQUM7O3NIQU5RLHlCQUF5QjswR0FBekIseUJBQXlCLGlGQ2J0QywyYkFXTTsyRkRFTyx5QkFBeUI7a0JBTnJDLFNBQVM7K0JBRUksb0JBQW9CIiwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUganNkb2MvcmVxdWlyZS1qc2RvYyAqL1xuaW1wb3J0IHsgQ29tcG9uZW50LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEJhc2VFbnRpdHlUeXBlIH0gZnJvbSAnLi4vLi4vLi4vLi4vY2xhc3Nlcy9lbnRpdHkubW9kZWwnO1xuaW1wb3J0IHsgRGVjb3JhdG9yVHlwZXMgfSBmcm9tICcuLi8uLi8uLi8uLi9kZWNvcmF0b3JzL2Jhc2UvZGVjb3JhdG9yLXR5cGVzLmVudW0nO1xuaW1wb3J0IHsgRmlsZURhdGEgfSBmcm9tICcuLi8uLi8uLi8uLi9kZWNvcmF0b3JzL2ZpbGUvZmlsZS1kZWNvcmF0b3IuZGF0YSc7XG5pbXBvcnQgeyBOZ3hNYXRFbnRpdHlCYXNlSW5wdXRDb21wb25lbnQgfSBmcm9tICcuLi8uLi9iYXNlLWlucHV0LmNvbXBvbmVudCc7XG5cbkBDb21wb25lbnQoe1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAYW5ndWxhci1lc2xpbnQvY29tcG9uZW50LXNlbGVjdG9yXG4gICAgc2VsZWN0b3I6ICdmaWxlLWRlZmF1bHQtaW5wdXQnLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9maWxlLWRlZmF1bHQtaW5wdXQuY29tcG9uZW50Lmh0bWwnLFxuICAgIHN0eWxlVXJsczogWycuL2ZpbGUtZGVmYXVsdC1pbnB1dC5jb21wb25lbnQuc2NzcyddXG59KVxuZXhwb3J0IGNsYXNzIEZpbGVEZWZhdWx0SW5wdXRDb21wb25lbnQ8RW50aXR5VHlwZSBleHRlbmRzIEJhc2VFbnRpdHlUeXBlPEVudGl0eVR5cGU+PlxuICAgIGV4dGVuZHMgTmd4TWF0RW50aXR5QmFzZUlucHV0Q29tcG9uZW50PEVudGl0eVR5cGUsIERlY29yYXRvclR5cGVzLkZJTEVfREVGQVVMVCwgRmlsZURhdGEgfCBGaWxlRGF0YVtdPiBpbXBsZW1lbnRzIE9uSW5pdCB7XG5cbiAgICBhc3luYyByZWZyZXNoRmlsZURhdGEoZmlsZURhdGE/OiBGaWxlRGF0YSB8IEZpbGVEYXRhW10pOiBQcm9taXNlPHZvaWQ+IHtcbiAgICAgICAgdGhpcy5wcm9wZXJ0eVZhbHVlID0gZmlsZURhdGE7XG4gICAgICAgIHRoaXMuZW1pdENoYW5nZSgpO1xuICAgIH1cbn0iLCI8ZGl2IFtjbGFzcy5maWxlLWlucHV0XT1cIm1ldGFkYXRhLmRyYWdBbmREcm9wXCIgW2NsYXNzLm1hdC1lbGV2YXRpb24tejhdPVwibWV0YWRhdGEuZHJhZ0FuZERyb3BcIj5cbiAgICA8ZmlsZS1pbnB1dFxuICAgICAgICAoZmlsZURhdGFDaGFuZ2VFdmVudCk9XCJyZWZyZXNoRmlsZURhdGEoJGV2ZW50KVwiXG4gICAgICAgIFtwcm9wZXJ0eVZhbHVlXT1cInByb3BlcnR5VmFsdWVcIlxuICAgICAgICBbbWV0YWRhdGFdPVwibWV0YWRhdGFcIlxuICAgICAgICBbZ2V0VmFsaWRhdGlvbkVycm9yTWVzc2FnZV09XCJnZXRWYWxpZGF0aW9uRXJyb3JNZXNzYWdlXCJcbiAgICAgICAgW2lzUmVhZE9ubHldPVwiaXNSZWFkT25seVwiXG4gICAgICAgIFtlbnRpdHldPVwiZW50aXR5XCJcbiAgICAgICAgW2tleV09XCJrZXlcIlxuICAgID5cbiAgICA8L2ZpbGUtaW5wdXQ+XG48L2Rpdj4iXX0=
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
/* eslint-disable jsdoc/require-jsdoc */
|
|
2
|
+
import { HttpClient } from '@angular/common/http';
|
|
2
3
|
import { Component } from '@angular/core';
|
|
3
4
|
import { ReflectUtilities } from '../../../../encapsulation/reflect.utilities';
|
|
4
5
|
import { placeholder } from '../../../../mocks/placeholder-data.png';
|
|
@@ -6,13 +7,14 @@ import { EntityUtilities } from '../../../../utilities/entity.utilities';
|
|
|
6
7
|
import { FileUtilities } from '../../../../utilities/file.utilities';
|
|
7
8
|
import { NgxMatEntityBaseInputComponent } from '../../base-input.component';
|
|
8
9
|
import * as i0 from "@angular/core";
|
|
9
|
-
import * as i1 from "@angular/common";
|
|
10
|
-
import * as i2 from "@angular/
|
|
11
|
-
import * as i3 from "
|
|
10
|
+
import * as i1 from "@angular/common/http";
|
|
11
|
+
import * as i2 from "@angular/common";
|
|
12
|
+
import * as i3 from "@angular/material/button";
|
|
13
|
+
import * as i4 from "../file-input/file-input.component";
|
|
12
14
|
export class FileImageInputComponent extends NgxMatEntityBaseInputComponent {
|
|
13
|
-
constructor() {
|
|
14
|
-
super(
|
|
15
|
-
this.
|
|
15
|
+
constructor(http) {
|
|
16
|
+
super();
|
|
17
|
+
this.http = http;
|
|
16
18
|
this.imageIndex = 0;
|
|
17
19
|
this.placeHolder = placeholder;
|
|
18
20
|
}
|
|
@@ -30,7 +32,7 @@ export class FileImageInputComponent extends NgxMatEntityBaseInputComponent {
|
|
|
30
32
|
}
|
|
31
33
|
async setSinglePreviewImage() {
|
|
32
34
|
if (this.propertyValue) {
|
|
33
|
-
this.propertyValue = await FileUtilities.getFileData(this.propertyValue);
|
|
35
|
+
this.propertyValue = await FileUtilities.getFileData(this.propertyValue, this.http);
|
|
34
36
|
this.singlePreviewImage = await FileUtilities.getDataURLFromFile(this.propertyValue.file);
|
|
35
37
|
}
|
|
36
38
|
else {
|
|
@@ -43,7 +45,7 @@ export class FileImageInputComponent extends NgxMatEntityBaseInputComponent {
|
|
|
43
45
|
if (multiFileData?.length) {
|
|
44
46
|
for (let i = 0; i < multiFileData.length; i++) {
|
|
45
47
|
if (i === index) {
|
|
46
|
-
multiFileData[index] = await FileUtilities.getFileData(multiFileData[index]);
|
|
48
|
+
multiFileData[index] = await FileUtilities.getFileData(multiFileData[index], this.http);
|
|
47
49
|
previewImages.push(await FileUtilities.getDataURLFromFile(multiFileData[index].file));
|
|
48
50
|
}
|
|
49
51
|
else {
|
|
@@ -89,10 +91,10 @@ export class FileImageInputComponent extends NgxMatEntityBaseInputComponent {
|
|
|
89
91
|
this.imageIndex = index;
|
|
90
92
|
}
|
|
91
93
|
}
|
|
92
|
-
FileImageInputComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.3", ngImport: i0, type: FileImageInputComponent, deps:
|
|
93
|
-
FileImageInputComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.3", type: FileImageInputComponent, selector: "file-image-input", usesInheritance: true, ngImport: i0, template: "<div *ngIf=\"!metadata.dragAndDrop && !metadata.preview\">\n <file-input\n (fileDataChangeEvent)=\"refreshFileData($event)\"\n [propertyValue]=\"propertyValue\"\n [metadata]=\"metadata\"\n [getValidationErrorMessage]=\"getValidationErrorMessage\"\n [isReadOnly]=\"isReadOnly\"\n [entity]=\"entity\"\n [key]=\"key\"\n >\n </file-input>\n</div>\n\n<div *ngIf=\"metadata.dragAndDrop || metadata.preview\" class=\"file-input mat-elevation-z8\">\n <file-input\n (fileDataChangeEvent)=\"refreshFileData($event)\"\n [propertyValue]=\"propertyValue\"\n [metadata]=\"metadata\"\n [getValidationErrorMessage]=\"getValidationErrorMessage\"\n [isReadOnly]=\"isReadOnly\"\n [entity]=\"entity\"\n [key]=\"key\"\n >\n </file-input>\n\n <div class=\"image-preview\" *ngIf=\"metadata.preview && metadata.multiple\">\n <i (click)=\"prev()\" [class.disabled]=\"imageIndex === 0\" class=\"prev-button fa-solid fa-angle-left\"></i>\n <img *ngIf=\"multiPreviewImages?.[imageIndex]\" class=\"mat-elevation-z2\" [src]=\"multiPreviewImages?.[imageIndex]\">\n <img *ngIf=\"!multiPreviewImages?.[imageIndex]\" class=\"mat-elevation-z2\" [src]=\"metadata.previewPlaceholderUrl ?? placeHolder\">\n <i (click)=\"next()\"\n [class.disabled]=\"!multiPreviewImages || !multiPreviewImages.length || imageIndex === (multiPreviewImages.length - 1)\"\n class=\"next-button fa-solid fa-angle-right\"\n >\n </i>\n </div>\n <div class=\"preview-nav\" *ngIf=\"metadata.preview && metadata.multiple\">\n <button type=\"button\" (click)=\"setIndex(imageIndex-4)\" mat-icon-button *ngIf=\"\n this.multiPreviewImages\n && multiPreviewImages[imageIndex-4]\n && imageIndex === (this.multiPreviewImages.length - 1)\"\n >\n <span class=\"dot\"></span>\n <span class=\"image-index\">{{imageIndex - 3}}</span>\n </button>\n <!-- eslint-disable-next-line @angular-eslint/template/conditional-complexity -->\n <button type=\"button\" (click)=\"setIndex(imageIndex-3)\" mat-icon-button *ngIf=\"this.multiPreviewImages\n && multiPreviewImages[imageIndex-3]\n && (\n imageIndex === (this.multiPreviewImages.length - 2)\n || imageIndex === (this.multiPreviewImages.length - 1)\n )\"\n >\n <span class=\"dot\"></span>\n <span class=\"image-index\">{{imageIndex - 2}}</span>\n </button>\n <button type=\"button\" (click)=\"setIndex(imageIndex-2)\" mat-icon-button *ngIf=\"multiPreviewImages?.[imageIndex-2]\">\n <span class=\"dot\"></span>\n <span class=\"image-index\">{{imageIndex - 1}}</span>\n </button>\n <button type=\"button\" (click)=\"setIndex(imageIndex-1)\" mat-icon-button *ngIf=\"multiPreviewImages?.[imageIndex-1]\">\n <i class=\"dot\"></i>\n <span class=\"image-index\">{{imageIndex}}</span>\n </button>\n <button type=\"button\" mat-icon-button disabled>\n <i class=\"dot selected\"></i>\n <span class=\"image-index\">{{imageIndex + 1}}</span>\n </button>\n <button type=\"button\" (click)=\"setIndex(imageIndex+1)\" mat-icon-button *ngIf=\"multiPreviewImages?.[imageIndex+1]\">\n <span class=\"dot\"></span>\n <span class=\"image-index\">{{imageIndex + 2}}</span>\n </button>\n <button type=\"button\" (click)=\"setIndex(imageIndex+2)\" mat-icon-button *ngIf=\"multiPreviewImages?.[imageIndex+2]\">\n <span class=\"dot\"></span>\n <span class=\"image-index\">{{imageIndex + 3}}</span>\n </button>\n <button type=\"button\" (click)=\"setIndex(imageIndex+3)\" mat-icon-button *ngIf=\"multiPreviewImages?.[imageIndex+3] && imageIndex <= 1\">\n <span class=\"dot\"></span>\n <span class=\"image-index\">{{imageIndex + 4}}</span>\n </button>\n <button type=\"button\" (click)=\"setIndex(imageIndex+4)\" mat-icon-button *ngIf=\"multiPreviewImages?.[imageIndex+4] && imageIndex === 0\">\n <span class=\"dot\"></span>\n <span class=\"image-index\">{{imageIndex + 5}}</span>\n </button>\n </div>\n\n <div class=\"image-preview\" *ngIf=\"metadata.preview && !metadata.multiple\">\n <i class=\"prev-button disabled fa-solid fa-angle-left\"></i>\n <img class=\"mat-elevation-z2\" [src]=\"singlePreviewImage ?? metadata.previewPlaceholderUrl ?? placeHolder\">\n <i class=\"next-button disabled fa-solid fa-angle-right\"></i>\n </div>\n <div class=\"preview-nav\" *ngIf=\"metadata.preview && !metadata.multiple\">\n <button type=\"button\" disabled mat-icon-button>\n <span class=\"dot selected\"></span>\n <span class=\"image-index\">1</span>\n </button>\n </div>\n</div>", styles: [".file-input{margin-top:15px;margin-bottom:15px;padding:15px;border-radius:5px}.image-preview{height:250px;display:flex;align-items:center;padding-top:15px;padding-bottom:15px}.image-preview .prev-button{font-size:100px;margin-left:5px;color:#0000008a}.image-preview .next-button{font-size:100px;margin-right:5px;color:#0000008a}.image-preview .prev-button:hover,.image-preview .next-button:hover{cursor:pointer;color:#000000b3;transition:all .5s ease}.image-preview .prev-button.disabled,.image-preview .next-button.disabled{color:#00000042}.image-preview .prev-button.disabled:hover,.image-preview .next-button.disabled:hover{color:#00000042;transition:none;cursor:default}.image-preview img{max-width:calc(100% - 100px);max-height:100%;margin-left:auto;margin-right:auto;border-radius:3px}.preview-nav{text-align:center}.preview-nav button{display:inline-block;width:18px;height:18px;margin-left:5px;margin-right:5px}.preview-nav button .dot{height:100%;width:100%;background-color:#00000061;border-radius:50%;display:block}.preview-nav button .dot.selected{background-color:#0000008a}.preview-nav button .image-index{position:absolute;height:100%;width:100%;display:block;top:-11.5px;color:#fff}.preview-nav button:hover .dot{background-color:#0000008a;transition:all .3s ease}\n"], dependencies: [{ kind: "directive", type:
|
|
94
|
+
FileImageInputComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.3", ngImport: i0, type: FileImageInputComponent, deps: [{ token: i1.HttpClient }], target: i0.ɵɵFactoryTarget.Component });
|
|
95
|
+
FileImageInputComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.3", type: FileImageInputComponent, selector: "file-image-input", usesInheritance: true, ngImport: i0, template: "<div *ngIf=\"!metadata.dragAndDrop && !metadata.preview\">\n <file-input\n (fileDataChangeEvent)=\"refreshFileData($event)\"\n [propertyValue]=\"propertyValue\"\n [metadata]=\"metadata\"\n [getValidationErrorMessage]=\"getValidationErrorMessage\"\n [isReadOnly]=\"isReadOnly\"\n [entity]=\"entity\"\n [key]=\"key\"\n >\n </file-input>\n</div>\n\n<div *ngIf=\"metadata.dragAndDrop || metadata.preview\" class=\"file-input mat-elevation-z8\">\n <file-input\n (fileDataChangeEvent)=\"refreshFileData($event)\"\n [propertyValue]=\"propertyValue\"\n [metadata]=\"metadata\"\n [getValidationErrorMessage]=\"getValidationErrorMessage\"\n [isReadOnly]=\"isReadOnly\"\n [entity]=\"entity\"\n [key]=\"key\"\n >\n </file-input>\n\n <div class=\"image-preview\" *ngIf=\"metadata.preview && metadata.multiple\">\n <i (click)=\"prev()\" [class.disabled]=\"imageIndex === 0\" class=\"prev-button fa-solid fa-angle-left\"></i>\n <img *ngIf=\"multiPreviewImages?.[imageIndex]\" class=\"mat-elevation-z2\" [src]=\"multiPreviewImages?.[imageIndex]\">\n <img *ngIf=\"!multiPreviewImages?.[imageIndex]\" class=\"mat-elevation-z2\" [src]=\"metadata.previewPlaceholderUrl ?? placeHolder\">\n <i (click)=\"next()\"\n [class.disabled]=\"!multiPreviewImages || !multiPreviewImages.length || imageIndex === (multiPreviewImages.length - 1)\"\n class=\"next-button fa-solid fa-angle-right\"\n >\n </i>\n </div>\n <div class=\"preview-nav\" *ngIf=\"metadata.preview && metadata.multiple\">\n <button type=\"button\" (click)=\"setIndex(imageIndex-4)\" mat-icon-button *ngIf=\"\n this.multiPreviewImages\n && multiPreviewImages[imageIndex-4]\n && imageIndex === (this.multiPreviewImages.length - 1)\"\n >\n <span class=\"dot\"></span>\n <span class=\"image-index\">{{imageIndex - 3}}</span>\n </button>\n <!-- eslint-disable-next-line @angular-eslint/template/conditional-complexity -->\n <button type=\"button\" (click)=\"setIndex(imageIndex-3)\" mat-icon-button *ngIf=\"this.multiPreviewImages\n && multiPreviewImages[imageIndex-3]\n && (\n imageIndex === (this.multiPreviewImages.length - 2)\n || imageIndex === (this.multiPreviewImages.length - 1)\n )\"\n >\n <span class=\"dot\"></span>\n <span class=\"image-index\">{{imageIndex - 2}}</span>\n </button>\n <button type=\"button\" (click)=\"setIndex(imageIndex-2)\" mat-icon-button *ngIf=\"multiPreviewImages?.[imageIndex-2]\">\n <span class=\"dot\"></span>\n <span class=\"image-index\">{{imageIndex - 1}}</span>\n </button>\n <button type=\"button\" (click)=\"setIndex(imageIndex-1)\" mat-icon-button *ngIf=\"multiPreviewImages?.[imageIndex-1]\">\n <i class=\"dot\"></i>\n <span class=\"image-index\">{{imageIndex}}</span>\n </button>\n <button type=\"button\" mat-icon-button disabled>\n <i class=\"dot selected\"></i>\n <span class=\"image-index\">{{imageIndex + 1}}</span>\n </button>\n <button type=\"button\" (click)=\"setIndex(imageIndex+1)\" mat-icon-button *ngIf=\"multiPreviewImages?.[imageIndex+1]\">\n <span class=\"dot\"></span>\n <span class=\"image-index\">{{imageIndex + 2}}</span>\n </button>\n <button type=\"button\" (click)=\"setIndex(imageIndex+2)\" mat-icon-button *ngIf=\"multiPreviewImages?.[imageIndex+2]\">\n <span class=\"dot\"></span>\n <span class=\"image-index\">{{imageIndex + 3}}</span>\n </button>\n <button type=\"button\" (click)=\"setIndex(imageIndex+3)\" mat-icon-button *ngIf=\"multiPreviewImages?.[imageIndex+3] && imageIndex <= 1\">\n <span class=\"dot\"></span>\n <span class=\"image-index\">{{imageIndex + 4}}</span>\n </button>\n <button type=\"button\" (click)=\"setIndex(imageIndex+4)\" mat-icon-button *ngIf=\"multiPreviewImages?.[imageIndex+4] && imageIndex === 0\">\n <span class=\"dot\"></span>\n <span class=\"image-index\">{{imageIndex + 5}}</span>\n </button>\n </div>\n\n <div class=\"image-preview\" *ngIf=\"metadata.preview && !metadata.multiple\">\n <i class=\"prev-button disabled fa-solid fa-angle-left\"></i>\n <img class=\"mat-elevation-z2\" [src]=\"singlePreviewImage ?? metadata.previewPlaceholderUrl ?? placeHolder\">\n <i class=\"next-button disabled fa-solid fa-angle-right\"></i>\n </div>\n <div class=\"preview-nav\" *ngIf=\"metadata.preview && !metadata.multiple\">\n <button type=\"button\" disabled mat-icon-button>\n <span class=\"dot selected\"></span>\n <span class=\"image-index\">1</span>\n </button>\n </div>\n</div>", styles: [".file-input{margin-top:15px;margin-bottom:15px;padding:15px;border-radius:5px}.image-preview{height:250px;display:flex;align-items:center;padding-top:15px;padding-bottom:15px}.image-preview .prev-button{font-size:100px;margin-left:5px;color:#0000008a}.image-preview .next-button{font-size:100px;margin-right:5px;color:#0000008a}.image-preview .prev-button:hover,.image-preview .next-button:hover{cursor:pointer;color:#000000b3;transition:all .5s ease}.image-preview .prev-button.disabled,.image-preview .next-button.disabled{color:#00000042}.image-preview .prev-button.disabled:hover,.image-preview .next-button.disabled:hover{color:#00000042;transition:none;cursor:default}.image-preview img{max-width:calc(100% - 100px);max-height:100%;margin-left:auto;margin-right:auto;border-radius:3px}.preview-nav{text-align:center}.preview-nav button{display:inline-block;width:18px;height:18px;margin-left:5px;margin-right:5px}.preview-nav button .dot{height:100%;width:100%;background-color:#00000061;border-radius:50%;display:block}.preview-nav button .dot.selected{background-color:#0000008a}.preview-nav button .image-index{position:absolute;height:100%;width:100%;display:block;top:-11.5px;color:#fff}.preview-nav button:hover .dot{background-color:#0000008a;transition:all .3s ease}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.MatIconButton, selector: "button[mat-icon-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i4.FileInputComponent, selector: "file-input", inputs: ["propertyValue", "entity", "key", "metadata", "getValidationErrorMessage", "isReadOnly"], outputs: ["fileDataChangeEvent"] }] });
|
|
94
96
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.3", ngImport: i0, type: FileImageInputComponent, decorators: [{
|
|
95
97
|
type: Component,
|
|
96
98
|
args: [{ selector: 'file-image-input', template: "<div *ngIf=\"!metadata.dragAndDrop && !metadata.preview\">\n <file-input\n (fileDataChangeEvent)=\"refreshFileData($event)\"\n [propertyValue]=\"propertyValue\"\n [metadata]=\"metadata\"\n [getValidationErrorMessage]=\"getValidationErrorMessage\"\n [isReadOnly]=\"isReadOnly\"\n [entity]=\"entity\"\n [key]=\"key\"\n >\n </file-input>\n</div>\n\n<div *ngIf=\"metadata.dragAndDrop || metadata.preview\" class=\"file-input mat-elevation-z8\">\n <file-input\n (fileDataChangeEvent)=\"refreshFileData($event)\"\n [propertyValue]=\"propertyValue\"\n [metadata]=\"metadata\"\n [getValidationErrorMessage]=\"getValidationErrorMessage\"\n [isReadOnly]=\"isReadOnly\"\n [entity]=\"entity\"\n [key]=\"key\"\n >\n </file-input>\n\n <div class=\"image-preview\" *ngIf=\"metadata.preview && metadata.multiple\">\n <i (click)=\"prev()\" [class.disabled]=\"imageIndex === 0\" class=\"prev-button fa-solid fa-angle-left\"></i>\n <img *ngIf=\"multiPreviewImages?.[imageIndex]\" class=\"mat-elevation-z2\" [src]=\"multiPreviewImages?.[imageIndex]\">\n <img *ngIf=\"!multiPreviewImages?.[imageIndex]\" class=\"mat-elevation-z2\" [src]=\"metadata.previewPlaceholderUrl ?? placeHolder\">\n <i (click)=\"next()\"\n [class.disabled]=\"!multiPreviewImages || !multiPreviewImages.length || imageIndex === (multiPreviewImages.length - 1)\"\n class=\"next-button fa-solid fa-angle-right\"\n >\n </i>\n </div>\n <div class=\"preview-nav\" *ngIf=\"metadata.preview && metadata.multiple\">\n <button type=\"button\" (click)=\"setIndex(imageIndex-4)\" mat-icon-button *ngIf=\"\n this.multiPreviewImages\n && multiPreviewImages[imageIndex-4]\n && imageIndex === (this.multiPreviewImages.length - 1)\"\n >\n <span class=\"dot\"></span>\n <span class=\"image-index\">{{imageIndex - 3}}</span>\n </button>\n <!-- eslint-disable-next-line @angular-eslint/template/conditional-complexity -->\n <button type=\"button\" (click)=\"setIndex(imageIndex-3)\" mat-icon-button *ngIf=\"this.multiPreviewImages\n && multiPreviewImages[imageIndex-3]\n && (\n imageIndex === (this.multiPreviewImages.length - 2)\n || imageIndex === (this.multiPreviewImages.length - 1)\n )\"\n >\n <span class=\"dot\"></span>\n <span class=\"image-index\">{{imageIndex - 2}}</span>\n </button>\n <button type=\"button\" (click)=\"setIndex(imageIndex-2)\" mat-icon-button *ngIf=\"multiPreviewImages?.[imageIndex-2]\">\n <span class=\"dot\"></span>\n <span class=\"image-index\">{{imageIndex - 1}}</span>\n </button>\n <button type=\"button\" (click)=\"setIndex(imageIndex-1)\" mat-icon-button *ngIf=\"multiPreviewImages?.[imageIndex-1]\">\n <i class=\"dot\"></i>\n <span class=\"image-index\">{{imageIndex}}</span>\n </button>\n <button type=\"button\" mat-icon-button disabled>\n <i class=\"dot selected\"></i>\n <span class=\"image-index\">{{imageIndex + 1}}</span>\n </button>\n <button type=\"button\" (click)=\"setIndex(imageIndex+1)\" mat-icon-button *ngIf=\"multiPreviewImages?.[imageIndex+1]\">\n <span class=\"dot\"></span>\n <span class=\"image-index\">{{imageIndex + 2}}</span>\n </button>\n <button type=\"button\" (click)=\"setIndex(imageIndex+2)\" mat-icon-button *ngIf=\"multiPreviewImages?.[imageIndex+2]\">\n <span class=\"dot\"></span>\n <span class=\"image-index\">{{imageIndex + 3}}</span>\n </button>\n <button type=\"button\" (click)=\"setIndex(imageIndex+3)\" mat-icon-button *ngIf=\"multiPreviewImages?.[imageIndex+3] && imageIndex <= 1\">\n <span class=\"dot\"></span>\n <span class=\"image-index\">{{imageIndex + 4}}</span>\n </button>\n <button type=\"button\" (click)=\"setIndex(imageIndex+4)\" mat-icon-button *ngIf=\"multiPreviewImages?.[imageIndex+4] && imageIndex === 0\">\n <span class=\"dot\"></span>\n <span class=\"image-index\">{{imageIndex + 5}}</span>\n </button>\n </div>\n\n <div class=\"image-preview\" *ngIf=\"metadata.preview && !metadata.multiple\">\n <i class=\"prev-button disabled fa-solid fa-angle-left\"></i>\n <img class=\"mat-elevation-z2\" [src]=\"singlePreviewImage ?? metadata.previewPlaceholderUrl ?? placeHolder\">\n <i class=\"next-button disabled fa-solid fa-angle-right\"></i>\n </div>\n <div class=\"preview-nav\" *ngIf=\"metadata.preview && !metadata.multiple\">\n <button type=\"button\" disabled mat-icon-button>\n <span class=\"dot selected\"></span>\n <span class=\"image-index\">1</span>\n </button>\n </div>\n</div>", styles: [".file-input{margin-top:15px;margin-bottom:15px;padding:15px;border-radius:5px}.image-preview{height:250px;display:flex;align-items:center;padding-top:15px;padding-bottom:15px}.image-preview .prev-button{font-size:100px;margin-left:5px;color:#0000008a}.image-preview .next-button{font-size:100px;margin-right:5px;color:#0000008a}.image-preview .prev-button:hover,.image-preview .next-button:hover{cursor:pointer;color:#000000b3;transition:all .5s ease}.image-preview .prev-button.disabled,.image-preview .next-button.disabled{color:#00000042}.image-preview .prev-button.disabled:hover,.image-preview .next-button.disabled:hover{color:#00000042;transition:none;cursor:default}.image-preview img{max-width:calc(100% - 100px);max-height:100%;margin-left:auto;margin-right:auto;border-radius:3px}.preview-nav{text-align:center}.preview-nav button{display:inline-block;width:18px;height:18px;margin-left:5px;margin-right:5px}.preview-nav button .dot{height:100%;width:100%;background-color:#00000061;border-radius:50%;display:block}.preview-nav button .dot.selected{background-color:#0000008a}.preview-nav button .image-index{position:absolute;height:100%;width:100%;display:block;top:-11.5px;color:#fff}.preview-nav button:hover .dot{background-color:#0000008a;transition:all .3s ease}\n"] }]
|
|
97
|
-
}] });
|
|
98
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-image-input.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-material-entity/src/components/input/file/file-image-input/file-image-input.component.ts","../../../../../../../projects/ngx-material-entity/src/components/input/file/file-image-input/file-image-input.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable jsdoc/require-jsdoc */\nimport { Component, OnInit } from '@angular/core';\nimport { BaseEntityType } from '../../../../classes/entity.model';\nimport { DecoratorTypes } from '../../../../decorators/base/decorator-types.enum';\nimport { FileData } from '../../../../decorators/file/file-decorator.data';\nimport { ReflectUtilities } from '../../../../encapsulation/reflect.utilities';\nimport { placeholder } from '../../../../mocks/placeholder-data.png';\nimport { EntityUtilities } from '../../../../utilities/entity.utilities';\nimport { FileUtilities } from '../../../../utilities/file.utilities';\nimport { NgxMatEntityBaseInputComponent } from '../../base-input.component';\n\n@Component({\n    // eslint-disable-next-line @angular-eslint/component-selector\n    selector: 'file-image-input',\n    templateUrl: './file-image-input.component.html',\n    styleUrls: ['./file-image-input.component.scss']\n})\nexport class FileImageInputComponent<EntityType extends BaseEntityType<EntityType>>\n    extends NgxMatEntityBaseInputComponent<EntityType, DecoratorTypes.FILE_IMAGE, FileData | FileData[]> implements OnInit {\n\n    FileUtilities: typeof FileUtilities = FileUtilities;\n\n    get multiPreviewImages(): string[] | undefined {\n        return ReflectUtilities.getMetadata(EntityUtilities.MULTI_PREVIEW_IMAGES_KEY, this.entity, this.key) as string[] | undefined;\n    }\n    set multiPreviewImages(value: string[] | undefined) {\n        ReflectUtilities.defineMetadata(EntityUtilities.MULTI_PREVIEW_IMAGES_KEY, value, this.entity, this.key);\n    }\n\n    get singlePreviewImage(): string | undefined {\n        return ReflectUtilities.getMetadata(EntityUtilities.SINGLE_PREVIEW_IMAGE_KEY, this.entity, this.key) as string | undefined;\n    }\n    set singlePreviewImage(value: string | undefined) {\n        ReflectUtilities.defineMetadata(EntityUtilities.SINGLE_PREVIEW_IMAGE_KEY, value, this.entity, this.key);\n    }\n\n    imageIndex: number = 0;\n    placeHolder: string = placeholder;\n\n    private async setSinglePreviewImage(): Promise<void> {\n        if (this.propertyValue) {\n            this.propertyValue = await FileUtilities.getFileData(this.propertyValue as FileData);\n            this.singlePreviewImage = await FileUtilities.getDataURLFromFile(this.propertyValue.file);\n        }\n        else {\n            this.singlePreviewImage = undefined;\n        }\n    }\n\n    private async setMultiPreviewImages(index: number): Promise<void> {\n        const multiFileData: FileData[] | undefined = this.propertyValue as FileData[] | undefined;\n        const previewImages: string[] = [];\n        if (multiFileData?.length) {\n            for (let i: number = 0; i < multiFileData.length; i++) {\n                if (i === index) {\n                    multiFileData[index] = await FileUtilities.getFileData(multiFileData[index]);\n                    previewImages.push(await FileUtilities.getDataURLFromFile(multiFileData[index].file) as string);\n                }\n                else {\n                    previewImages.push('empty');\n                }\n            }\n        }\n        this.multiPreviewImages = previewImages;\n    }\n\n    async refreshFileData(fileData?: FileData | FileData[]): Promise<void> {\n        this.propertyValue = fileData;\n        this.emitChange();\n        if (this.metadata.multiple) {\n            fileData = (fileData as FileData[] | undefined);\n            if (!fileData?.[this.imageIndex]) {\n                this.imageIndex = 0;\n            }\n            await this.setMultiPreviewImages(this.imageIndex);\n        }\n        else {\n            await this.setSinglePreviewImage();\n        }\n    }\n\n    async prev(): Promise<void> {\n        if (this.imageIndex <= 0) {\n            return;\n        }\n        await this.setMultiPreviewImages(this.imageIndex - 1);\n        this.imageIndex--;\n    }\n\n    async next(): Promise<void> {\n        if (!this.multiPreviewImages?.length) {\n            return;\n        }\n        if (this.imageIndex === (this.multiPreviewImages.length - 1)) {\n            return;\n        }\n        await this.setMultiPreviewImages(this.imageIndex + 1);\n        this.imageIndex++;\n    }\n\n    async setIndex(index: number): Promise<void> {\n        await this.setMultiPreviewImages(index);\n        this.imageIndex = index;\n    }\n}","<div *ngIf=\"!metadata.dragAndDrop && !metadata.preview\">\n    <file-input\n        (fileDataChangeEvent)=\"refreshFileData($event)\"\n        [propertyValue]=\"propertyValue\"\n        [metadata]=\"metadata\"\n        [getValidationErrorMessage]=\"getValidationErrorMessage\"\n        [isReadOnly]=\"isReadOnly\"\n        [entity]=\"entity\"\n        [key]=\"key\"\n    >\n    </file-input>\n</div>\n\n<div *ngIf=\"metadata.dragAndDrop || metadata.preview\" class=\"file-input mat-elevation-z8\">\n    <file-input\n        (fileDataChangeEvent)=\"refreshFileData($event)\"\n        [propertyValue]=\"propertyValue\"\n        [metadata]=\"metadata\"\n        [getValidationErrorMessage]=\"getValidationErrorMessage\"\n        [isReadOnly]=\"isReadOnly\"\n        [entity]=\"entity\"\n        [key]=\"key\"\n    >\n    </file-input>\n\n    <div class=\"image-preview\" *ngIf=\"metadata.preview && metadata.multiple\">\n        <i (click)=\"prev()\" [class.disabled]=\"imageIndex === 0\" class=\"prev-button fa-solid fa-angle-left\"></i>\n        <img *ngIf=\"multiPreviewImages?.[imageIndex]\" class=\"mat-elevation-z2\" [src]=\"multiPreviewImages?.[imageIndex]\">\n        <img *ngIf=\"!multiPreviewImages?.[imageIndex]\" class=\"mat-elevation-z2\" [src]=\"metadata.previewPlaceholderUrl ?? placeHolder\">\n        <i (click)=\"next()\"\n            [class.disabled]=\"!multiPreviewImages || !multiPreviewImages.length || imageIndex === (multiPreviewImages.length - 1)\"\n            class=\"next-button fa-solid fa-angle-right\"\n        >\n        </i>\n    </div>\n    <div class=\"preview-nav\" *ngIf=\"metadata.preview && metadata.multiple\">\n        <button type=\"button\" (click)=\"setIndex(imageIndex-4)\" mat-icon-button *ngIf=\"\n            this.multiPreviewImages\n            && multiPreviewImages[imageIndex-4]\n            && imageIndex === (this.multiPreviewImages.length - 1)\"\n        >\n            <span class=\"dot\"></span>\n            <span class=\"image-index\">{{imageIndex - 3}}</span>\n        </button>\n        <!-- eslint-disable-next-line @angular-eslint/template/conditional-complexity -->\n        <button type=\"button\" (click)=\"setIndex(imageIndex-3)\" mat-icon-button *ngIf=\"this.multiPreviewImages\n            && multiPreviewImages[imageIndex-3]\n            && (\n                imageIndex === (this.multiPreviewImages.length - 2)\n                || imageIndex === (this.multiPreviewImages.length - 1)\n            )\"\n        >\n            <span class=\"dot\"></span>\n            <span class=\"image-index\">{{imageIndex - 2}}</span>\n        </button>\n        <button type=\"button\" (click)=\"setIndex(imageIndex-2)\" mat-icon-button *ngIf=\"multiPreviewImages?.[imageIndex-2]\">\n            <span class=\"dot\"></span>\n            <span class=\"image-index\">{{imageIndex - 1}}</span>\n        </button>\n        <button type=\"button\" (click)=\"setIndex(imageIndex-1)\" mat-icon-button *ngIf=\"multiPreviewImages?.[imageIndex-1]\">\n            <i class=\"dot\"></i>\n            <span class=\"image-index\">{{imageIndex}}</span>\n        </button>\n        <button type=\"button\" mat-icon-button disabled>\n            <i class=\"dot selected\"></i>\n            <span class=\"image-index\">{{imageIndex + 1}}</span>\n        </button>\n        <button type=\"button\" (click)=\"setIndex(imageIndex+1)\" mat-icon-button *ngIf=\"multiPreviewImages?.[imageIndex+1]\">\n            <span class=\"dot\"></span>\n            <span class=\"image-index\">{{imageIndex + 2}}</span>\n        </button>\n        <button type=\"button\" (click)=\"setIndex(imageIndex+2)\" mat-icon-button *ngIf=\"multiPreviewImages?.[imageIndex+2]\">\n            <span class=\"dot\"></span>\n            <span class=\"image-index\">{{imageIndex + 3}}</span>\n        </button>\n        <button type=\"button\" (click)=\"setIndex(imageIndex+3)\" mat-icon-button *ngIf=\"multiPreviewImages?.[imageIndex+3] && imageIndex <= 1\">\n            <span class=\"dot\"></span>\n            <span class=\"image-index\">{{imageIndex + 4}}</span>\n        </button>\n        <button type=\"button\" (click)=\"setIndex(imageIndex+4)\" mat-icon-button *ngIf=\"multiPreviewImages?.[imageIndex+4] && imageIndex === 0\">\n            <span class=\"dot\"></span>\n            <span class=\"image-index\">{{imageIndex + 5}}</span>\n        </button>\n    </div>\n\n    <div class=\"image-preview\" *ngIf=\"metadata.preview && !metadata.multiple\">\n        <i class=\"prev-button disabled fa-solid fa-angle-left\"></i>\n        <img class=\"mat-elevation-z2\" [src]=\"singlePreviewImage ?? metadata.previewPlaceholderUrl ?? placeHolder\">\n        <i class=\"next-button disabled fa-solid fa-angle-right\"></i>\n    </div>\n    <div class=\"preview-nav\" *ngIf=\"metadata.preview && !metadata.multiple\">\n        <button type=\"button\" disabled mat-icon-button>\n            <span class=\"dot selected\"></span>\n            <span class=\"image-index\">1</span>\n        </button>\n    </div>\n</div>"]}
|
|
99
|
+
}], ctorParameters: function () { return [{ type: i1.HttpClient }]; } });
|
|
100
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-image-input.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-material-entity/src/components/input/file/file-image-input/file-image-input.component.ts","../../../../../../../projects/ngx-material-entity/src/components/input/file/file-image-input/file-image-input.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable jsdoc/require-jsdoc */\nimport { HttpClient } from '@angular/common/http';\nimport { Component, OnInit } from '@angular/core';\nimport { BaseEntityType } from '../../../../classes/entity.model';\nimport { DecoratorTypes } from '../../../../decorators/base/decorator-types.enum';\nimport { FileData } from '../../../../decorators/file/file-decorator.data';\nimport { ReflectUtilities } from '../../../../encapsulation/reflect.utilities';\nimport { placeholder } from '../../../../mocks/placeholder-data.png';\nimport { EntityUtilities } from '../../../../utilities/entity.utilities';\nimport { FileUtilities } from '../../../../utilities/file.utilities';\nimport { NgxMatEntityBaseInputComponent } from '../../base-input.component';\n\n@Component({\n    // eslint-disable-next-line @angular-eslint/component-selector\n    selector: 'file-image-input',\n    templateUrl: './file-image-input.component.html',\n    styleUrls: ['./file-image-input.component.scss']\n})\nexport class FileImageInputComponent<EntityType extends BaseEntityType<EntityType>>\n    extends NgxMatEntityBaseInputComponent<EntityType, DecoratorTypes.FILE_IMAGE, FileData | FileData[]> implements OnInit {\n\n    get multiPreviewImages(): string[] | undefined {\n        return ReflectUtilities.getMetadata(EntityUtilities.MULTI_PREVIEW_IMAGES_KEY, this.entity, this.key) as string[] | undefined;\n    }\n    set multiPreviewImages(value: string[] | undefined) {\n        ReflectUtilities.defineMetadata(EntityUtilities.MULTI_PREVIEW_IMAGES_KEY, value, this.entity, this.key);\n    }\n\n    get singlePreviewImage(): string | undefined {\n        return ReflectUtilities.getMetadata(EntityUtilities.SINGLE_PREVIEW_IMAGE_KEY, this.entity, this.key) as string | undefined;\n    }\n    set singlePreviewImage(value: string | undefined) {\n        ReflectUtilities.defineMetadata(EntityUtilities.SINGLE_PREVIEW_IMAGE_KEY, value, this.entity, this.key);\n    }\n\n    imageIndex: number = 0;\n    placeHolder: string = placeholder;\n\n    constructor(private readonly http: HttpClient) {\n        super();\n    }\n\n    private async setSinglePreviewImage(): Promise<void> {\n        if (this.propertyValue) {\n            this.propertyValue = await FileUtilities.getFileData(this.propertyValue as FileData, this.http);\n            this.singlePreviewImage = await FileUtilities.getDataURLFromFile(this.propertyValue.file);\n        }\n        else {\n            this.singlePreviewImage = undefined;\n        }\n    }\n\n    private async setMultiPreviewImages(index: number): Promise<void> {\n        const multiFileData: FileData[] | undefined = this.propertyValue as FileData[] | undefined;\n        const previewImages: string[] = [];\n        if (multiFileData?.length) {\n            for (let i: number = 0; i < multiFileData.length; i++) {\n                if (i === index) {\n                    multiFileData[index] = await FileUtilities.getFileData(multiFileData[index], this.http);\n                    previewImages.push(await FileUtilities.getDataURLFromFile(multiFileData[index].file) as string);\n                }\n                else {\n                    previewImages.push('empty');\n                }\n            }\n        }\n        this.multiPreviewImages = previewImages;\n    }\n\n    async refreshFileData(fileData?: FileData | FileData[]): Promise<void> {\n        this.propertyValue = fileData;\n        this.emitChange();\n        if (this.metadata.multiple) {\n            fileData = (fileData as FileData[] | undefined);\n            if (!fileData?.[this.imageIndex]) {\n                this.imageIndex = 0;\n            }\n            await this.setMultiPreviewImages(this.imageIndex);\n        }\n        else {\n            await this.setSinglePreviewImage();\n        }\n    }\n\n    async prev(): Promise<void> {\n        if (this.imageIndex <= 0) {\n            return;\n        }\n        await this.setMultiPreviewImages(this.imageIndex - 1);\n        this.imageIndex--;\n    }\n\n    async next(): Promise<void> {\n        if (!this.multiPreviewImages?.length) {\n            return;\n        }\n        if (this.imageIndex === (this.multiPreviewImages.length - 1)) {\n            return;\n        }\n        await this.setMultiPreviewImages(this.imageIndex + 1);\n        this.imageIndex++;\n    }\n\n    async setIndex(index: number): Promise<void> {\n        await this.setMultiPreviewImages(index);\n        this.imageIndex = index;\n    }\n}","<div *ngIf=\"!metadata.dragAndDrop && !metadata.preview\">\n    <file-input\n        (fileDataChangeEvent)=\"refreshFileData($event)\"\n        [propertyValue]=\"propertyValue\"\n        [metadata]=\"metadata\"\n        [getValidationErrorMessage]=\"getValidationErrorMessage\"\n        [isReadOnly]=\"isReadOnly\"\n        [entity]=\"entity\"\n        [key]=\"key\"\n    >\n    </file-input>\n</div>\n\n<div *ngIf=\"metadata.dragAndDrop || metadata.preview\" class=\"file-input mat-elevation-z8\">\n    <file-input\n        (fileDataChangeEvent)=\"refreshFileData($event)\"\n        [propertyValue]=\"propertyValue\"\n        [metadata]=\"metadata\"\n        [getValidationErrorMessage]=\"getValidationErrorMessage\"\n        [isReadOnly]=\"isReadOnly\"\n        [entity]=\"entity\"\n        [key]=\"key\"\n    >\n    </file-input>\n\n    <div class=\"image-preview\" *ngIf=\"metadata.preview && metadata.multiple\">\n        <i (click)=\"prev()\" [class.disabled]=\"imageIndex === 0\" class=\"prev-button fa-solid fa-angle-left\"></i>\n        <img *ngIf=\"multiPreviewImages?.[imageIndex]\" class=\"mat-elevation-z2\" [src]=\"multiPreviewImages?.[imageIndex]\">\n        <img *ngIf=\"!multiPreviewImages?.[imageIndex]\" class=\"mat-elevation-z2\" [src]=\"metadata.previewPlaceholderUrl ?? placeHolder\">\n        <i (click)=\"next()\"\n            [class.disabled]=\"!multiPreviewImages || !multiPreviewImages.length || imageIndex === (multiPreviewImages.length - 1)\"\n            class=\"next-button fa-solid fa-angle-right\"\n        >\n        </i>\n    </div>\n    <div class=\"preview-nav\" *ngIf=\"metadata.preview && metadata.multiple\">\n        <button type=\"button\" (click)=\"setIndex(imageIndex-4)\" mat-icon-button *ngIf=\"\n            this.multiPreviewImages\n            && multiPreviewImages[imageIndex-4]\n            && imageIndex === (this.multiPreviewImages.length - 1)\"\n        >\n            <span class=\"dot\"></span>\n            <span class=\"image-index\">{{imageIndex - 3}}</span>\n        </button>\n        <!-- eslint-disable-next-line @angular-eslint/template/conditional-complexity -->\n        <button type=\"button\" (click)=\"setIndex(imageIndex-3)\" mat-icon-button *ngIf=\"this.multiPreviewImages\n            && multiPreviewImages[imageIndex-3]\n            && (\n                imageIndex === (this.multiPreviewImages.length - 2)\n                || imageIndex === (this.multiPreviewImages.length - 1)\n            )\"\n        >\n            <span class=\"dot\"></span>\n            <span class=\"image-index\">{{imageIndex - 2}}</span>\n        </button>\n        <button type=\"button\" (click)=\"setIndex(imageIndex-2)\" mat-icon-button *ngIf=\"multiPreviewImages?.[imageIndex-2]\">\n            <span class=\"dot\"></span>\n            <span class=\"image-index\">{{imageIndex - 1}}</span>\n        </button>\n        <button type=\"button\" (click)=\"setIndex(imageIndex-1)\" mat-icon-button *ngIf=\"multiPreviewImages?.[imageIndex-1]\">\n            <i class=\"dot\"></i>\n            <span class=\"image-index\">{{imageIndex}}</span>\n        </button>\n        <button type=\"button\" mat-icon-button disabled>\n            <i class=\"dot selected\"></i>\n            <span class=\"image-index\">{{imageIndex + 1}}</span>\n        </button>\n        <button type=\"button\" (click)=\"setIndex(imageIndex+1)\" mat-icon-button *ngIf=\"multiPreviewImages?.[imageIndex+1]\">\n            <span class=\"dot\"></span>\n            <span class=\"image-index\">{{imageIndex + 2}}</span>\n        </button>\n        <button type=\"button\" (click)=\"setIndex(imageIndex+2)\" mat-icon-button *ngIf=\"multiPreviewImages?.[imageIndex+2]\">\n            <span class=\"dot\"></span>\n            <span class=\"image-index\">{{imageIndex + 3}}</span>\n        </button>\n        <button type=\"button\" (click)=\"setIndex(imageIndex+3)\" mat-icon-button *ngIf=\"multiPreviewImages?.[imageIndex+3] && imageIndex <= 1\">\n            <span class=\"dot\"></span>\n            <span class=\"image-index\">{{imageIndex + 4}}</span>\n        </button>\n        <button type=\"button\" (click)=\"setIndex(imageIndex+4)\" mat-icon-button *ngIf=\"multiPreviewImages?.[imageIndex+4] && imageIndex === 0\">\n            <span class=\"dot\"></span>\n            <span class=\"image-index\">{{imageIndex + 5}}</span>\n        </button>\n    </div>\n\n    <div class=\"image-preview\" *ngIf=\"metadata.preview && !metadata.multiple\">\n        <i class=\"prev-button disabled fa-solid fa-angle-left\"></i>\n        <img class=\"mat-elevation-z2\" [src]=\"singlePreviewImage ?? metadata.previewPlaceholderUrl ?? placeHolder\">\n        <i class=\"next-button disabled fa-solid fa-angle-right\"></i>\n    </div>\n    <div class=\"preview-nav\" *ngIf=\"metadata.preview && !metadata.multiple\">\n        <button type=\"button\" disabled mat-icon-button>\n            <span class=\"dot selected\"></span>\n            <span class=\"image-index\">1</span>\n        </button>\n    </div>\n</div>"]}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
/* eslint-disable jsdoc/require-jsdoc */
|
|
2
|
+
import { HttpClient } from '@angular/common/http';
|
|
2
3
|
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
3
4
|
import { MatDialog } from '@angular/material/dialog';
|
|
4
5
|
import { LodashUtilities } from '../../../../encapsulation/lodash.utilities';
|
|
@@ -8,15 +9,17 @@ import { FileUtilities } from '../../../../utilities/file.utilities';
|
|
|
8
9
|
import { NgxMatEntityConfirmDialogComponent } from '../../../confirm-dialog/confirm-dialog.component';
|
|
9
10
|
import * as i0 from "@angular/core";
|
|
10
11
|
import * as i1 from "@angular/material/dialog";
|
|
11
|
-
import * as i2 from "@angular/common";
|
|
12
|
-
import * as i3 from "@angular/
|
|
13
|
-
import * as i4 from "@angular/
|
|
14
|
-
import * as i5 from "@angular/
|
|
15
|
-
import * as i6 from "@angular/material/
|
|
16
|
-
import * as i7 from "
|
|
12
|
+
import * as i2 from "@angular/common/http";
|
|
13
|
+
import * as i3 from "@angular/common";
|
|
14
|
+
import * as i4 from "@angular/material/form-field";
|
|
15
|
+
import * as i5 from "@angular/forms";
|
|
16
|
+
import * as i6 from "@angular/material/chips";
|
|
17
|
+
import * as i7 from "@angular/material/button";
|
|
18
|
+
import * as i8 from "./dragDrop.directive";
|
|
17
19
|
export class FileInputComponent {
|
|
18
|
-
constructor(dialog) {
|
|
20
|
+
constructor(dialog, http) {
|
|
19
21
|
this.dialog = dialog;
|
|
22
|
+
this.http = http;
|
|
20
23
|
this.FileUtilities = FileUtilities;
|
|
21
24
|
this.fileDataChangeEvent = new EventEmitter();
|
|
22
25
|
}
|
|
@@ -145,11 +148,11 @@ export class FileInputComponent {
|
|
|
145
148
|
// the index need to be saved in a constant because we edit foundFileData
|
|
146
149
|
// => .indexOf() returns undefined.
|
|
147
150
|
const index = this.propertyValue.indexOf(foundFileData);
|
|
148
|
-
this.propertyValue[index] = await FileUtilities.getFileData(foundFileData);
|
|
151
|
+
this.propertyValue[index] = await FileUtilities.getFileData(foundFileData, this.http);
|
|
149
152
|
FileUtilities.downloadSingleFile(this.propertyValue[index]);
|
|
150
153
|
}
|
|
151
154
|
else if (this.propertyValue) {
|
|
152
|
-
this.propertyValue = await FileUtilities.getFileData(this.propertyValue);
|
|
155
|
+
this.propertyValue = await FileUtilities.getFileData(this.propertyValue, this.http);
|
|
153
156
|
FileUtilities.downloadSingleFile(this.propertyValue);
|
|
154
157
|
}
|
|
155
158
|
}
|
|
@@ -168,16 +171,16 @@ export class FileInputComponent {
|
|
|
168
171
|
async downloadAll() {
|
|
169
172
|
if (this.propertyValue.length) {
|
|
170
173
|
// eslint-disable-next-line max-len
|
|
171
|
-
void FileUtilities.downloadMultipleFiles(this.metadata.displayName, LodashUtilities.cloneDeep(this.propertyValue));
|
|
174
|
+
void FileUtilities.downloadMultipleFiles(this.metadata.displayName, LodashUtilities.cloneDeep(this.propertyValue), this.http);
|
|
172
175
|
}
|
|
173
176
|
}
|
|
174
177
|
}
|
|
175
|
-
FileInputComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.3", ngImport: i0, type: FileInputComponent, deps: [{ token: i1.MatDialog }], target: i0.ɵɵFactoryTarget.Component });
|
|
176
|
-
FileInputComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.3", type: FileInputComponent, selector: "file-input", inputs: { propertyValue: "propertyValue", entity: "entity", key: "key", metadata: "metadata", getValidationErrorMessage: "getValidationErrorMessage", isReadOnly: "isReadOnly" }, outputs: { fileDataChangeEvent: "fileDataChangeEvent" }, ngImport: i0, template: "<input #fileInput\n type=\"file\" hidden\n [multiple]=\"metadata.multiple\"\n [accept]=\"FileUtilities.getAcceptString(metadata.allowedMimeTypes)\"\n (change)=\"setFileFromInput($event)\"\n>\n\n<mat-form-field floatLabel=\"always\">\n <mat-label>{{metadata.displayName}}</mat-label>\n <mat-chip-grid #chipGrid\n [(ngModel)]=\"filenames\" name=\"file\" #model=\"ngModel\"\n [required]=\"metadata.required(entity)\"\n >\n <mat-chip-row *ngFor=\"let name of filenames\" (removed)=\"removeFile(name)\">\n {{name}}\n <span class=\"mat-mdc-chip-remove mat-mdc-chip-trailing-icon ngx-mat-grey\" (click)=\"downloadFile(name)\">\n <i class=\"fas fa-download\"></i>\n </span>\n <button *ngIf=\"!isReadOnly\" type=\"button\" matChipRemove>\n <i class=\"{{metadata.deleteIcon}}\"></i>\n </button>\n </mat-chip-row>\n <input [matChipInputFor]=\"chipGrid\" [readonly]=\"true\" hidden>\n </mat-chip-grid>\n <button *ngIf=\"downloadAllEnabled()\" type=\"button\" class=\"ngx-mat-grey\" mat-icon-button matSuffix (click)=\"downloadAll()\">\n <i class=\"fas fa-file-zipper\"></i>\n </button>\n <button type=\"button\" class=\"ngx-mat-grey\" mat-icon-button matSuffix [disabled]=\"isReadOnly\" (click)=\"fileInput.click()\">\n <i class=\"fas fa-upload\"></i>\n </button>\n <mat-error>{{getValidationErrorMessage(model)}}</mat-error>\n</mat-form-field>\n\n<div *ngIf=\"metadata.dragAndDrop && !isReadOnly\" class=\"drag-drop\" dragDrop (files)=\"setFile($event)\">\n <button type=\"button\" mat-icon-button [disabled]=\"isReadOnly\" (click)=\"fileInput.click()\">\n <i class=\"fas fa-file-arrow-up ngx-mat-grey\"></i>\n </button>\n</div>", styles: ["mat-form-field{width:100%}.ngx-mat-grey{opacity:1;color:#0000008a}.drag-drop{display:flex;align-items:center;justify-content:center;height:200px;border:2px dashed rgba(0,0,0,.54);border-radius:15px;margin-top:5px;margin-bottom:5px}.drag-drop i{font-size:30px}\n"], dependencies: [{ kind: "directive", type:
|
|
178
|
+
FileInputComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.3", ngImport: i0, type: FileInputComponent, deps: [{ token: i1.MatDialog }, { token: i2.HttpClient }], target: i0.ɵɵFactoryTarget.Component });
|
|
179
|
+
FileInputComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.3", type: FileInputComponent, selector: "file-input", inputs: { propertyValue: "propertyValue", entity: "entity", key: "key", metadata: "metadata", getValidationErrorMessage: "getValidationErrorMessage", isReadOnly: "isReadOnly" }, outputs: { fileDataChangeEvent: "fileDataChangeEvent" }, ngImport: i0, template: "<input #fileInput\n type=\"file\" hidden\n [multiple]=\"metadata.multiple\"\n [accept]=\"FileUtilities.getAcceptString(metadata.allowedMimeTypes)\"\n (change)=\"setFileFromInput($event)\"\n>\n\n<mat-form-field floatLabel=\"always\">\n <mat-label>{{metadata.displayName}}</mat-label>\n <mat-chip-grid #chipGrid\n [(ngModel)]=\"filenames\" name=\"file\" #model=\"ngModel\"\n [required]=\"metadata.required(entity)\"\n >\n <mat-chip-row *ngFor=\"let name of filenames\" (removed)=\"removeFile(name)\">\n {{name}}\n <span class=\"mat-mdc-chip-remove mat-mdc-chip-trailing-icon ngx-mat-grey\" (click)=\"downloadFile(name)\">\n <i class=\"fas fa-download\"></i>\n </span>\n <button *ngIf=\"!isReadOnly\" type=\"button\" matChipRemove>\n <i class=\"{{metadata.deleteIcon}}\"></i>\n </button>\n </mat-chip-row>\n <input [matChipInputFor]=\"chipGrid\" [readonly]=\"true\" hidden>\n </mat-chip-grid>\n <button *ngIf=\"downloadAllEnabled()\" type=\"button\" class=\"ngx-mat-grey\" mat-icon-button matSuffix (click)=\"downloadAll()\">\n <i class=\"fas fa-file-zipper\"></i>\n </button>\n <button type=\"button\" class=\"ngx-mat-grey\" mat-icon-button matSuffix [disabled]=\"isReadOnly\" (click)=\"fileInput.click()\">\n <i class=\"fas fa-upload\"></i>\n </button>\n <mat-error>{{getValidationErrorMessage(model)}}</mat-error>\n</mat-form-field>\n\n<div *ngIf=\"metadata.dragAndDrop && !isReadOnly\" class=\"drag-drop\" dragDrop (files)=\"setFile($event)\">\n <button type=\"button\" mat-icon-button [disabled]=\"isReadOnly\" (click)=\"fileInput.click()\">\n <i class=\"fas fa-file-arrow-up ngx-mat-grey\"></i>\n </button>\n</div>", styles: ["mat-form-field{width:100%}.ngx-mat-grey{opacity:1;color:#0000008a}.drag-drop{display:flex;align-items:center;justify-content:center;height:200px;border:2px dashed rgba(0,0,0,.54);border-radius:15px;margin-top:5px;margin-bottom:5px}.drag-drop i{font-size:30px}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i4.MatLabel, selector: "mat-label" }, { kind: "directive", type: i4.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "directive", type: i4.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i6.MatChipGrid, selector: "mat-chip-grid", inputs: ["tabIndex", "disabled", "placeholder", "required", "value", "errorStateMatcher"], outputs: ["change", "valueChange"] }, { kind: "directive", type: i6.MatChipInput, selector: "input[matChipInputFor]", inputs: ["matChipInputFor", "matChipInputAddOnBlur", "matChipInputSeparatorKeyCodes", "placeholder", "id", "disabled"], outputs: ["matChipInputTokenEnd"], exportAs: ["matChipInput", "matChipInputFor"] }, { kind: "directive", type: i6.MatChipRemove, selector: "[matChipRemove]" }, { kind: "component", type: i6.MatChipRow, selector: "mat-chip-row, [mat-chip-row], mat-basic-chip-row, [mat-basic-chip-row]", inputs: ["color", "disabled", "disableRipple", "tabIndex", "editable"], outputs: ["edited"] }, { kind: "component", type: i7.MatIconButton, selector: "button[mat-icon-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "directive", type: i8.DragDropDirective, selector: "[dragDrop]", outputs: ["files"] }] });
|
|
177
180
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.3", ngImport: i0, type: FileInputComponent, decorators: [{
|
|
178
181
|
type: Component,
|
|
179
182
|
args: [{ selector: 'file-input', template: "<input #fileInput\n type=\"file\" hidden\n [multiple]=\"metadata.multiple\"\n [accept]=\"FileUtilities.getAcceptString(metadata.allowedMimeTypes)\"\n (change)=\"setFileFromInput($event)\"\n>\n\n<mat-form-field floatLabel=\"always\">\n <mat-label>{{metadata.displayName}}</mat-label>\n <mat-chip-grid #chipGrid\n [(ngModel)]=\"filenames\" name=\"file\" #model=\"ngModel\"\n [required]=\"metadata.required(entity)\"\n >\n <mat-chip-row *ngFor=\"let name of filenames\" (removed)=\"removeFile(name)\">\n {{name}}\n <span class=\"mat-mdc-chip-remove mat-mdc-chip-trailing-icon ngx-mat-grey\" (click)=\"downloadFile(name)\">\n <i class=\"fas fa-download\"></i>\n </span>\n <button *ngIf=\"!isReadOnly\" type=\"button\" matChipRemove>\n <i class=\"{{metadata.deleteIcon}}\"></i>\n </button>\n </mat-chip-row>\n <input [matChipInputFor]=\"chipGrid\" [readonly]=\"true\" hidden>\n </mat-chip-grid>\n <button *ngIf=\"downloadAllEnabled()\" type=\"button\" class=\"ngx-mat-grey\" mat-icon-button matSuffix (click)=\"downloadAll()\">\n <i class=\"fas fa-file-zipper\"></i>\n </button>\n <button type=\"button\" class=\"ngx-mat-grey\" mat-icon-button matSuffix [disabled]=\"isReadOnly\" (click)=\"fileInput.click()\">\n <i class=\"fas fa-upload\"></i>\n </button>\n <mat-error>{{getValidationErrorMessage(model)}}</mat-error>\n</mat-form-field>\n\n<div *ngIf=\"metadata.dragAndDrop && !isReadOnly\" class=\"drag-drop\" dragDrop (files)=\"setFile($event)\">\n <button type=\"button\" mat-icon-button [disabled]=\"isReadOnly\" (click)=\"fileInput.click()\">\n <i class=\"fas fa-file-arrow-up ngx-mat-grey\"></i>\n </button>\n</div>", styles: ["mat-form-field{width:100%}.ngx-mat-grey{opacity:1;color:#0000008a}.drag-drop{display:flex;align-items:center;justify-content:center;height:200px;border:2px dashed rgba(0,0,0,.54);border-radius:15px;margin-top:5px;margin-bottom:5px}.drag-drop i{font-size:30px}\n"] }]
|
|
180
|
-
}], ctorParameters: function () { return [{ type: i1.MatDialog }]; }, propDecorators: { propertyValue: [{
|
|
183
|
+
}], ctorParameters: function () { return [{ type: i1.MatDialog }, { type: i2.HttpClient }]; }, propDecorators: { propertyValue: [{
|
|
181
184
|
type: Input
|
|
182
185
|
}], entity: [{
|
|
183
186
|
type: Input
|
|
@@ -192,4 +195,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.3", ngImpor
|
|
|
192
195
|
}], fileDataChangeEvent: [{
|
|
193
196
|
type: Output
|
|
194
197
|
}] } });
|
|
195
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-input.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-material-entity/src/components/input/file/file-input/file-input.component.ts","../../../../../../../projects/ngx-material-entity/src/components/input/file/file-input/file-input.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable jsdoc/require-jsdoc */\nimport { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { NgModel } from '@angular/forms';\nimport { MatDialog } from '@angular/material/dialog';\nimport { BaseEntityType } from '../../../../classes/entity.model';\nimport { DefaultFileDecoratorConfigInternal, FileDataWithFile, ImageFileDecoratorConfigInternal } from '../../../../decorators/file/file-decorator-internal.data';\nimport { FileData } from '../../../../decorators/file/file-decorator.data';\nimport { LodashUtilities } from '../../../../encapsulation/lodash.utilities';\nimport { ReflectUtilities } from '../../../../encapsulation/reflect.utilities';\nimport { EntityUtilities } from '../../../../utilities/entity.utilities';\nimport { FileUtilities } from '../../../../utilities/file.utilities';\nimport { NgxMatEntityConfirmDialogComponent } from '../../../confirm-dialog/confirm-dialog.component';\n\n@Component({\n    // eslint-disable-next-line @angular-eslint/component-selector\n    selector: 'file-input',\n    templateUrl: './file-input.component.html',\n    styleUrls: ['./file-input.component.scss']\n})\nexport class FileInputComponent<EntityType extends BaseEntityType<EntityType>> implements OnInit {\n\n    get filenames(): string[] | undefined {\n        return ReflectUtilities.getMetadata(EntityUtilities.FILENAMES_KEY, this.entity, this.key) as string[] | undefined;\n    }\n    set filenames(value: string[] | undefined) {\n        ReflectUtilities.defineMetadata(EntityUtilities.FILENAMES_KEY, value, this.entity, this.key);\n    }\n\n    FileUtilities: typeof FileUtilities = FileUtilities;\n\n    @Input()\n    propertyValue!: FileData | FileData[] | undefined;\n\n    @Input()\n    entity!: EntityType;\n\n    @Input()\n    key!: keyof EntityType;\n\n    @Input()\n    metadata!: DefaultFileDecoratorConfigInternal | ImageFileDecoratorConfigInternal;\n\n    @Input()\n    getValidationErrorMessage!: (model: NgModel) => string;\n\n    @Input()\n    isReadOnly!: boolean;\n\n    @Output()\n    fileDataChangeEvent: EventEmitter<FileData | FileData[]> = new EventEmitter<FileData | FileData[]>();\n\n    constructor(private readonly dialog: MatDialog) { }\n\n    async ngOnInit(): Promise<void> {\n        if (this.metadata.multiple) {\n            this.initMultiFile();\n        }\n        else {\n            this.initSingleFile();\n        }\n        this.fileDataChangeEvent.emit(this.propertyValue);\n    }\n\n    private initMultiFile(): void {\n        if (this.propertyValue) {\n            this.filenames = (this.propertyValue as FileData[]).map(f => f.name);\n        }\n    }\n\n    private initSingleFile(): void {\n        if (this.propertyValue) {\n            this.filenames = [(this.propertyValue as FileData).name];\n        }\n    }\n\n    async setFileFromInput(event: Event): Promise<void> {\n        const files: FileList | [] = (event.target as HTMLInputElement).files ?? [];\n        await this.setFile(Array.from(files));\n    }\n\n    async setFile(files: File[]): Promise<void> {\n        // validation done inline\n        if (files.find(f => !FileUtilities.isMimeTypeValid(f.type, this.metadata.allowedMimeTypes))) {\n            this.dialog.open(NgxMatEntityConfirmDialogComponent, {\n                data: this.metadata.mimeTypeErrorDialog,\n                autoFocus: false,\n                restoreFocus: false\n            });\n            this.resetFileInputs();\n            return;\n        }\n        if (files.find(f => FileUtilities.transformToMegaBytes(f.size, 'B') > this.metadata.maxSize)) {\n            this.dialog.open(NgxMatEntityConfirmDialogComponent, {\n                data: this.metadata.maxSizeErrorDialog,\n                autoFocus: false,\n                restoreFocus: false\n            });\n            this.resetFileInputs();\n            return;\n        }\n        let fileSizeTotal: number = 0;\n        for (const file of files) {\n            fileSizeTotal += file.size;\n        }\n        if (FileUtilities.transformToMegaBytes(fileSizeTotal, 'B') > this.metadata.maxSizeTotal) {\n            this.dialog.open(NgxMatEntityConfirmDialogComponent, {\n                data: this.metadata.maxSizeTotalErrorDialog,\n                autoFocus: false,\n                restoreFocus: false\n            });\n            this.resetFileInputs();\n            return;\n        }\n        if (this.metadata.multiple) {\n            await this.setMultiFile(Array.from(files));\n        }\n        else {\n            await this.setSingleFile(files[0]);\n        }\n        this.fileDataChangeEvent.emit(this.propertyValue);\n    }\n\n    private resetFileInputs(): void {\n        this.filenames = undefined;\n        this.propertyValue = undefined;\n        this.fileDataChangeEvent.emit(this.propertyValue);\n    }\n\n    private async setMultiFile(files: File[]): Promise<void> {\n        const data: FileData[] = [];\n        for (const file of files) {\n            const fileData: FileData = {\n                file: file,\n                name: file.name,\n                type: file.type,\n                size: file.size\n            };\n            data.push(fileData);\n        }\n        this.propertyValue = LodashUtilities.cloneDeep(data);\n        this.filenames = this.propertyValue.map(f => f.name);\n    }\n\n    private async setSingleFile(file: File): Promise<void> {\n        this.propertyValue = {\n            file: file,\n            name: file.name,\n            type: file.type,\n            size: file.size\n        };\n        this.filenames = [this.propertyValue.name];\n    }\n\n    removeFile(name: string): void {\n        if (this.isReadOnly) {\n            return;\n        }\n        if (this.metadata.multiple) {\n            this.filenames?.splice(this.filenames.indexOf(name), 1);\n            if (!this.filenames?.length) {\n                this.filenames = undefined;\n            }\n            const fileDataToRemove: FileData = (this.propertyValue as FileData[]).find(f => f.name === name) as FileData;\n            (this.propertyValue as FileData[]).splice((this.propertyValue as FileData[]).indexOf(fileDataToRemove), 1);\n            if (!(this.propertyValue as FileData[]).length) {\n                this.propertyValue = undefined;\n            }\n        }\n        else {\n            this.filenames = undefined;\n            this.propertyValue = undefined;\n        }\n        this.fileDataChangeEvent.emit(this.propertyValue);\n    }\n\n    async downloadFile(name: string): Promise<void> {\n        if (this.metadata.multiple && (this.propertyValue as FileData[]).length) {\n            const foundFileData: FileData = (this.propertyValue as FileData[]).find(f => f.name === name) as FileData;\n            // the index need to be saved in a constant because we edit foundFileData\n            // => .indexOf() returns undefined.\n            const index: number = (this.propertyValue as FileData[]).indexOf(foundFileData);\n            (this.propertyValue as FileData[])[index] = await FileUtilities.getFileData(foundFileData);\n            FileUtilities.downloadSingleFile((this.propertyValue as FileData[])[index] as FileDataWithFile);\n        }\n        else if (this.propertyValue) {\n            this.propertyValue = await FileUtilities.getFileData(this.propertyValue as FileData);\n            FileUtilities.downloadSingleFile(this.propertyValue);\n        }\n    }\n\n    downloadAllEnabled(): boolean {\n        if (!this.metadata.multiple) {\n            return false;\n        }\n        if (!this.propertyValue) {\n            return false;\n        }\n        if ((this.propertyValue as FileData[]).length < 2) {\n            return false;\n        }\n        return true;\n    }\n\n    async downloadAll(): Promise<void> {\n        if ((this.propertyValue as FileData[]).length) {\n            // eslint-disable-next-line max-len\n            void FileUtilities.downloadMultipleFiles(this.metadata.displayName, LodashUtilities.cloneDeep(this.propertyValue as FileData[]));\n        }\n    }\n}","<input #fileInput\n    type=\"file\" hidden\n    [multiple]=\"metadata.multiple\"\n    [accept]=\"FileUtilities.getAcceptString(metadata.allowedMimeTypes)\"\n    (change)=\"setFileFromInput($event)\"\n>\n\n<mat-form-field floatLabel=\"always\">\n    <mat-label>{{metadata.displayName}}</mat-label>\n    <mat-chip-grid #chipGrid\n        [(ngModel)]=\"filenames\" name=\"file\" #model=\"ngModel\"\n        [required]=\"metadata.required(entity)\"\n    >\n        <mat-chip-row *ngFor=\"let name of filenames\" (removed)=\"removeFile(name)\">\n            {{name}}\n            <span class=\"mat-mdc-chip-remove mat-mdc-chip-trailing-icon ngx-mat-grey\" (click)=\"downloadFile(name)\">\n                <i class=\"fas fa-download\"></i>\n            </span>\n            <button *ngIf=\"!isReadOnly\" type=\"button\" matChipRemove>\n                <i class=\"{{metadata.deleteIcon}}\"></i>\n            </button>\n        </mat-chip-row>\n        <input [matChipInputFor]=\"chipGrid\" [readonly]=\"true\" hidden>\n    </mat-chip-grid>\n    <button *ngIf=\"downloadAllEnabled()\" type=\"button\" class=\"ngx-mat-grey\" mat-icon-button matSuffix (click)=\"downloadAll()\">\n        <i class=\"fas fa-file-zipper\"></i>\n    </button>\n    <button type=\"button\" class=\"ngx-mat-grey\" mat-icon-button matSuffix [disabled]=\"isReadOnly\" (click)=\"fileInput.click()\">\n        <i class=\"fas fa-upload\"></i>\n    </button>\n    <mat-error>{{getValidationErrorMessage(model)}}</mat-error>\n</mat-form-field>\n\n<div *ngIf=\"metadata.dragAndDrop && !isReadOnly\" class=\"drag-drop\" dragDrop (files)=\"setFile($event)\">\n    <button type=\"button\" mat-icon-button [disabled]=\"isReadOnly\" (click)=\"fileInput.click()\">\n        <i class=\"fas fa-file-arrow-up ngx-mat-grey\"></i>\n    </button>\n</div>"]}
|
|
198
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-input.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-material-entity/src/components/input/file/file-input/file-input.component.ts","../../../../../../../projects/ngx-material-entity/src/components/input/file/file-input/file-input.component.html"],"names":[],"mappings":"AAAA,wCAAwC;AACxC,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAClD,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAU,MAAM,EAAE,MAAM,eAAe,CAAC;AAE/E,OAAO,EAAE,SAAS,EAAE,MAAM,0BAA0B,CAAC;AAIrD,OAAO,EAAE,eAAe,EAAE,MAAM,4CAA4C,CAAC;AAC7E,OAAO,EAAE,gBAAgB,EAAE,MAAM,6CAA6C,CAAC;AAC/E,OAAO,EAAE,eAAe,EAAE,MAAM,wCAAwC,CAAC;AACzE,OAAO,EAAE,aAAa,EAAE,MAAM,sCAAsC,CAAC;AACrE,OAAO,EAAE,kCAAkC,EAAE,MAAM,kDAAkD,CAAC;;;;;;;;;;AAQtG,MAAM,OAAO,kBAAkB;IAgC3B,YAA6B,MAAiB,EAAmB,IAAgB;QAApD,WAAM,GAAN,MAAM,CAAW;QAAmB,SAAI,GAAJ,IAAI,CAAY;QAvBjF,kBAAa,GAAyB,aAAa,CAAC;QAqBpD,wBAAmB,GAAwC,IAAI,YAAY,EAAyB,CAAC;IAEhB,CAAC;IA9BtF,IAAI,SAAS;QACT,OAAO,gBAAgB,CAAC,WAAW,CAAC,eAAe,CAAC,aAAa,EAAE,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,GAAG,CAAyB,CAAC;IACtH,CAAC;IACD,IAAI,SAAS,CAAC,KAA2B;QACrC,gBAAgB,CAAC,cAAc,CAAC,eAAe,CAAC,aAAa,EAAE,KAAK,EAAE,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC;IACjG,CAAC;IA2BD,KAAK,CAAC,QAAQ;QACV,IAAI,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE;YACxB,IAAI,CAAC,aAAa,EAAE,CAAC;SACxB;aACI;YACD,IAAI,CAAC,cAAc,EAAE,CAAC;SACzB;QACD,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;IACtD,CAAC;IAEO,aAAa;QACjB,IAAI,IAAI,CAAC,aAAa,EAAE;YACpB,IAAI,CAAC,SAAS,GAAI,IAAI,CAAC,aAA4B,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;SACxE;IACL,CAAC;IAEO,cAAc;QAClB,IAAI,IAAI,CAAC,aAAa,EAAE;YACpB,IAAI,CAAC,SAAS,GAAG,CAAE,IAAI,CAAC,aAA0B,CAAC,IAAI,CAAC,CAAC;SAC5D;IACL,CAAC;IAED,KAAK,CAAC,gBAAgB,CAAC,KAAY;QAC/B,MAAM,KAAK,GAAmB,KAAK,CAAC,MAA2B,CAAC,KAAK,IAAI,EAAE,CAAC;QAC5E,MAAM,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;IAC1C,CAAC;IAED,KAAK,CAAC,OAAO,CAAC,KAAa;QACvB,yBAAyB;QACzB,IAAI,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,aAAa,CAAC,eAAe,CAAC,CAAC,CAAC,IAAI,EAAE,IAAI,CAAC,QAAQ,CAAC,gBAAgB,CAAC,CAAC,EAAE;YACzF,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,kCAAkC,EAAE;gBACjD,IAAI,EAAE,IAAI,CAAC,QAAQ,CAAC,mBAAmB;gBACvC,SAAS,EAAE,KAAK;gBAChB,YAAY,EAAE,KAAK;aACtB,CAAC,CAAC;YACH,IAAI,CAAC,eAAe,EAAE,CAAC;YACvB,OAAO;SACV;QACD,IAAI,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,aAAa,CAAC,oBAAoB,CAAC,CAAC,CAAC,IAAI,EAAE,GAAG,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,EAAE;YAC1F,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,kCAAkC,EAAE;gBACjD,IAAI,EAAE,IAAI,CAAC,QAAQ,CAAC,kBAAkB;gBACtC,SAAS,EAAE,KAAK;gBAChB,YAAY,EAAE,KAAK;aACtB,CAAC,CAAC;YACH,IAAI,CAAC,eAAe,EAAE,CAAC;YACvB,OAAO;SACV;QACD,IAAI,aAAa,GAAW,CAAC,CAAC;QAC9B,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE;YACtB,aAAa,IAAI,IAAI,CAAC,IAAI,CAAC;SAC9B;QACD,IAAI,aAAa,CAAC,oBAAoB,CAAC,aAAa,EAAE,GAAG,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC,YAAY,EAAE;YACrF,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,kCAAkC,EAAE;gBACjD,IAAI,EAAE,IAAI,CAAC,QAAQ,CAAC,uBAAuB;gBAC3C,SAAS,EAAE,KAAK;gBAChB,YAAY,EAAE,KAAK;aACtB,CAAC,CAAC;YACH,IAAI,CAAC,eAAe,EAAE,CAAC;YACvB,OAAO;SACV;QACD,IAAI,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE;YACxB,MAAM,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;SAC9C;aACI;YACD,MAAM,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;SACtC;QACD,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;IACtD,CAAC;IAEO,eAAe;QACnB,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;QAC3B,IAAI,CAAC,aAAa,GAAG,SAAS,CAAC;QAC/B,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;IACtD,CAAC;IAEO,KAAK,CAAC,YAAY,CAAC,KAAa;QACpC,MAAM,IAAI,GAAe,EAAE,CAAC;QAC5B,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE;YACtB,MAAM,QAAQ,GAAa;gBACvB,IAAI,EAAE,IAAI;gBACV,IAAI,EAAE,IAAI,CAAC,IAAI;gBACf,IAAI,EAAE,IAAI,CAAC,IAAI;gBACf,IAAI,EAAE,IAAI,CAAC,IAAI;aAClB,CAAC;YACF,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;SACvB;QACD,IAAI,CAAC,aAAa,GAAG,eAAe,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QACrD,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;IACzD,CAAC;IAEO,KAAK,CAAC,aAAa,CAAC,IAAU;QAClC,IAAI,CAAC,aAAa,GAAG;YACjB,IAAI,EAAE,IAAI;YACV,IAAI,EAAE,IAAI,CAAC,IAAI;YACf,IAAI,EAAE,IAAI,CAAC,IAAI;YACf,IAAI,EAAE,IAAI,CAAC,IAAI;SAClB,CAAC;QACF,IAAI,CAAC,SAAS,GAAG,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;IAC/C,CAAC;IAED,UAAU,CAAC,IAAY;QACnB,IAAI,IAAI,CAAC,UAAU,EAAE;YACjB,OAAO;SACV;QACD,IAAI,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE;YACxB,IAAI,CAAC,SAAS,EAAE,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC;YACxD,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,MAAM,EAAE;gBACzB,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;aAC9B;YACD,MAAM,gBAAgB,GAAc,IAAI,CAAC,aAA4B,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,IAAI,CAAa,CAAC;YAC5G,IAAI,CAAC,aAA4B,CAAC,MAAM,CAAE,IAAI,CAAC,aAA4B,CAAC,OAAO,CAAC,gBAAgB,CAAC,EAAE,CAAC,CAAC,CAAC;YAC3G,IAAI,CAAE,IAAI,CAAC,aAA4B,CAAC,MAAM,EAAE;gBAC5C,IAAI,CAAC,aAAa,GAAG,SAAS,CAAC;aAClC;SACJ;aACI;YACD,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;YAC3B,IAAI,CAAC,aAAa,GAAG,SAAS,CAAC;SAClC;QACD,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;IACtD,CAAC;IAED,KAAK,CAAC,YAAY,CAAC,IAAY;QAC3B,IAAI,IAAI,CAAC,QAAQ,CAAC,QAAQ,IAAK,IAAI,CAAC,aAA4B,CAAC,MAAM,EAAE;YACrE,MAAM,aAAa,GAAc,IAAI,CAAC,aAA4B,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,IAAI,CAAa,CAAC;YAC1G,yEAAyE;YACzE,mCAAmC;YACnC,MAAM,KAAK,GAAY,IAAI,CAAC,aAA4B,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;YAC/E,IAAI,CAAC,aAA4B,CAAC,KAAK,CAAC,GAAG,MAAM,aAAa,CAAC,WAAW,CAAC,aAAa,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;YACtG,aAAa,CAAC,kBAAkB,CAAE,IAAI,CAAC,aAA4B,CAAC,KAAK,CAAqB,CAAC,CAAC;SACnG;aACI,IAAI,IAAI,CAAC,aAAa,EAAE;YACzB,IAAI,CAAC,aAAa,GAAG,MAAM,aAAa,CAAC,WAAW,CAAC,IAAI,CAAC,aAAyB,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;YAChG,aAAa,CAAC,kBAAkB,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;SACxD;IACL,CAAC;IAED,kBAAkB;QACd,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE;YACzB,OAAO,KAAK,CAAC;SAChB;QACD,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE;YACrB,OAAO,KAAK,CAAC;SAChB;QACD,IAAK,IAAI,CAAC,aAA4B,CAAC,MAAM,GAAG,CAAC,EAAE;YAC/C,OAAO,KAAK,CAAC;SAChB;QACD,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,KAAK,CAAC,WAAW;QACb,IAAK,IAAI,CAAC,aAA4B,CAAC,MAAM,EAAE;YAC3C,mCAAmC;YACnC,KAAK,aAAa,CAAC,qBAAqB,CAAC,IAAI,CAAC,QAAQ,CAAC,WAAW,EAAE,eAAe,CAAC,SAAS,CAAC,IAAI,CAAC,aAA2B,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;SAC/I;IACL,CAAC;;+GA7LQ,kBAAkB;mGAAlB,kBAAkB,6RCpB/B,6wDAqCM;2FDjBO,kBAAkB;kBAN9B,SAAS;+BAEI,YAAY;yHAgBtB,aAAa;sBADZ,KAAK;gBAIN,MAAM;sBADL,KAAK;gBAIN,GAAG;sBADF,KAAK;gBAIN,QAAQ;sBADP,KAAK;gBAIN,yBAAyB;sBADxB,KAAK;gBAIN,UAAU;sBADT,KAAK;gBAIN,mBAAmB;sBADlB,MAAM","sourcesContent":["/* eslint-disable jsdoc/require-jsdoc */\nimport { HttpClient } from '@angular/common/http';\nimport { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { NgModel } from '@angular/forms';\nimport { MatDialog } from '@angular/material/dialog';\nimport { BaseEntityType } from '../../../../classes/entity.model';\nimport { DefaultFileDecoratorConfigInternal, FileDataWithFile, ImageFileDecoratorConfigInternal } from '../../../../decorators/file/file-decorator-internal.data';\nimport { FileData } from '../../../../decorators/file/file-decorator.data';\nimport { LodashUtilities } from '../../../../encapsulation/lodash.utilities';\nimport { ReflectUtilities } from '../../../../encapsulation/reflect.utilities';\nimport { EntityUtilities } from '../../../../utilities/entity.utilities';\nimport { FileUtilities } from '../../../../utilities/file.utilities';\nimport { NgxMatEntityConfirmDialogComponent } from '../../../confirm-dialog/confirm-dialog.component';\n\n@Component({\n    // eslint-disable-next-line @angular-eslint/component-selector\n    selector: 'file-input',\n    templateUrl: './file-input.component.html',\n    styleUrls: ['./file-input.component.scss']\n})\nexport class FileInputComponent<EntityType extends BaseEntityType<EntityType>> implements OnInit {\n\n    get filenames(): string[] | undefined {\n        return ReflectUtilities.getMetadata(EntityUtilities.FILENAMES_KEY, this.entity, this.key) as string[] | undefined;\n    }\n    set filenames(value: string[] | undefined) {\n        ReflectUtilities.defineMetadata(EntityUtilities.FILENAMES_KEY, value, this.entity, this.key);\n    }\n\n    FileUtilities: typeof FileUtilities = FileUtilities;\n\n    @Input()\n    propertyValue!: FileData | FileData[] | undefined;\n\n    @Input()\n    entity!: EntityType;\n\n    @Input()\n    key!: keyof EntityType;\n\n    @Input()\n    metadata!: DefaultFileDecoratorConfigInternal | ImageFileDecoratorConfigInternal;\n\n    @Input()\n    getValidationErrorMessage!: (model: NgModel) => string;\n\n    @Input()\n    isReadOnly!: boolean;\n\n    @Output()\n    fileDataChangeEvent: EventEmitter<FileData | FileData[]> = new EventEmitter<FileData | FileData[]>();\n\n    constructor(private readonly dialog: MatDialog, private readonly http: HttpClient) { }\n\n    async ngOnInit(): Promise<void> {\n        if (this.metadata.multiple) {\n            this.initMultiFile();\n        }\n        else {\n            this.initSingleFile();\n        }\n        this.fileDataChangeEvent.emit(this.propertyValue);\n    }\n\n    private initMultiFile(): void {\n        if (this.propertyValue) {\n            this.filenames = (this.propertyValue as FileData[]).map(f => f.name);\n        }\n    }\n\n    private initSingleFile(): void {\n        if (this.propertyValue) {\n            this.filenames = [(this.propertyValue as FileData).name];\n        }\n    }\n\n    async setFileFromInput(event: Event): Promise<void> {\n        const files: FileList | [] = (event.target as HTMLInputElement).files ?? [];\n        await this.setFile(Array.from(files));\n    }\n\n    async setFile(files: File[]): Promise<void> {\n        // validation done inline\n        if (files.find(f => !FileUtilities.isMimeTypeValid(f.type, this.metadata.allowedMimeTypes))) {\n            this.dialog.open(NgxMatEntityConfirmDialogComponent, {\n                data: this.metadata.mimeTypeErrorDialog,\n                autoFocus: false,\n                restoreFocus: false\n            });\n            this.resetFileInputs();\n            return;\n        }\n        if (files.find(f => FileUtilities.transformToMegaBytes(f.size, 'B') > this.metadata.maxSize)) {\n            this.dialog.open(NgxMatEntityConfirmDialogComponent, {\n                data: this.metadata.maxSizeErrorDialog,\n                autoFocus: false,\n                restoreFocus: false\n            });\n            this.resetFileInputs();\n            return;\n        }\n        let fileSizeTotal: number = 0;\n        for (const file of files) {\n            fileSizeTotal += file.size;\n        }\n        if (FileUtilities.transformToMegaBytes(fileSizeTotal, 'B') > this.metadata.maxSizeTotal) {\n            this.dialog.open(NgxMatEntityConfirmDialogComponent, {\n                data: this.metadata.maxSizeTotalErrorDialog,\n                autoFocus: false,\n                restoreFocus: false\n            });\n            this.resetFileInputs();\n            return;\n        }\n        if (this.metadata.multiple) {\n            await this.setMultiFile(Array.from(files));\n        }\n        else {\n            await this.setSingleFile(files[0]);\n        }\n        this.fileDataChangeEvent.emit(this.propertyValue);\n    }\n\n    private resetFileInputs(): void {\n        this.filenames = undefined;\n        this.propertyValue = undefined;\n        this.fileDataChangeEvent.emit(this.propertyValue);\n    }\n\n    private async setMultiFile(files: File[]): Promise<void> {\n        const data: FileData[] = [];\n        for (const file of files) {\n            const fileData: FileData = {\n                file: file,\n                name: file.name,\n                type: file.type,\n                size: file.size\n            };\n            data.push(fileData);\n        }\n        this.propertyValue = LodashUtilities.cloneDeep(data);\n        this.filenames = this.propertyValue.map(f => f.name);\n    }\n\n    private async setSingleFile(file: File): Promise<void> {\n        this.propertyValue = {\n            file: file,\n            name: file.name,\n            type: file.type,\n            size: file.size\n        };\n        this.filenames = [this.propertyValue.name];\n    }\n\n    removeFile(name: string): void {\n        if (this.isReadOnly) {\n            return;\n        }\n        if (this.metadata.multiple) {\n            this.filenames?.splice(this.filenames.indexOf(name), 1);\n            if (!this.filenames?.length) {\n                this.filenames = undefined;\n            }\n            const fileDataToRemove: FileData = (this.propertyValue as FileData[]).find(f => f.name === name) as FileData;\n            (this.propertyValue as FileData[]).splice((this.propertyValue as FileData[]).indexOf(fileDataToRemove), 1);\n            if (!(this.propertyValue as FileData[]).length) {\n                this.propertyValue = undefined;\n            }\n        }\n        else {\n            this.filenames = undefined;\n            this.propertyValue = undefined;\n        }\n        this.fileDataChangeEvent.emit(this.propertyValue);\n    }\n\n    async downloadFile(name: string): Promise<void> {\n        if (this.metadata.multiple && (this.propertyValue as FileData[]).length) {\n            const foundFileData: FileData = (this.propertyValue as FileData[]).find(f => f.name === name) as FileData;\n            // the index need to be saved in a constant because we edit foundFileData\n            // => .indexOf() returns undefined.\n            const index: number = (this.propertyValue as FileData[]).indexOf(foundFileData);\n            (this.propertyValue as FileData[])[index] = await FileUtilities.getFileData(foundFileData, this.http);\n            FileUtilities.downloadSingleFile((this.propertyValue as FileData[])[index] as FileDataWithFile);\n        }\n        else if (this.propertyValue) {\n            this.propertyValue = await FileUtilities.getFileData(this.propertyValue as FileData, this.http);\n            FileUtilities.downloadSingleFile(this.propertyValue);\n        }\n    }\n\n    downloadAllEnabled(): boolean {\n        if (!this.metadata.multiple) {\n            return false;\n        }\n        if (!this.propertyValue) {\n            return false;\n        }\n        if ((this.propertyValue as FileData[]).length < 2) {\n            return false;\n        }\n        return true;\n    }\n\n    async downloadAll(): Promise<void> {\n        if ((this.propertyValue as FileData[]).length) {\n            // eslint-disable-next-line max-len\n            void FileUtilities.downloadMultipleFiles(this.metadata.displayName, LodashUtilities.cloneDeep(this.propertyValue as FileData[]), this.http);\n        }\n    }\n}","<input #fileInput\n    type=\"file\" hidden\n    [multiple]=\"metadata.multiple\"\n    [accept]=\"FileUtilities.getAcceptString(metadata.allowedMimeTypes)\"\n    (change)=\"setFileFromInput($event)\"\n>\n\n<mat-form-field floatLabel=\"always\">\n    <mat-label>{{metadata.displayName}}</mat-label>\n    <mat-chip-grid #chipGrid\n        [(ngModel)]=\"filenames\" name=\"file\" #model=\"ngModel\"\n        [required]=\"metadata.required(entity)\"\n    >\n        <mat-chip-row *ngFor=\"let name of filenames\" (removed)=\"removeFile(name)\">\n            {{name}}\n            <span class=\"mat-mdc-chip-remove mat-mdc-chip-trailing-icon ngx-mat-grey\" (click)=\"downloadFile(name)\">\n                <i class=\"fas fa-download\"></i>\n            </span>\n            <button *ngIf=\"!isReadOnly\" type=\"button\" matChipRemove>\n                <i class=\"{{metadata.deleteIcon}}\"></i>\n            </button>\n        </mat-chip-row>\n        <input [matChipInputFor]=\"chipGrid\" [readonly]=\"true\" hidden>\n    </mat-chip-grid>\n    <button *ngIf=\"downloadAllEnabled()\" type=\"button\" class=\"ngx-mat-grey\" mat-icon-button matSuffix (click)=\"downloadAll()\">\n        <i class=\"fas fa-file-zipper\"></i>\n    </button>\n    <button type=\"button\" class=\"ngx-mat-grey\" mat-icon-button matSuffix [disabled]=\"isReadOnly\" (click)=\"fileInput.click()\">\n        <i class=\"fas fa-upload\"></i>\n    </button>\n    <mat-error>{{getValidationErrorMessage(model)}}</mat-error>\n</mat-form-field>\n\n<div *ngIf=\"metadata.dragAndDrop && !isReadOnly\" class=\"drag-drop\" dragDrop (files)=\"setFile($event)\">\n    <button type=\"button\" mat-icon-button [disabled]=\"isReadOnly\" (click)=\"fileInput.click()\">\n        <i class=\"fas fa-file-arrow-up ngx-mat-grey\"></i>\n    </button>\n</div>"]}
|