ngx-material-entity 1.1.4 → 1.1.5
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/classes/selection.utilities.d.ts +31 -0
- package/components/get-validation-error-message.function.d.ts +1 -10
- package/components/input/array/array-string-autocomplete-chips/array-string-autocomplete-chips.component.d.ts +1 -0
- package/components/input/array/array-string-chips-input/array-string-chips-input.component.d.ts +1 -0
- package/components/input/array/array-table.class.d.ts +2 -12
- package/components/input/custom/custom.component.d.ts +1 -1
- package/components/input/input.component.d.ts +3 -21
- package/components/table/table.component.d.ts +2 -11
- package/decorators/custom/custom-decorator-internal.data.d.ts +1 -1
- package/decorators/custom/custom-decorator.data.d.ts +3 -3
- package/decorators/custom/custom.decorator.d.ts +1 -3
- package/{capsulation → encapsulation}/jszip.utilities.d.ts +0 -0
- package/{capsulation → encapsulation}/lodash.utilities.d.ts +0 -0
- package/{capsulation → encapsulation}/reflect.utilities.d.ts +0 -0
- package/esm2020/classes/date.utilities.mjs +2 -2
- package/esm2020/classes/entity.service.mjs +37 -4
- package/esm2020/classes/entity.utilities.mjs +12 -10
- package/esm2020/classes/file.utilities.mjs +3 -3
- package/esm2020/classes/selection.utilities.mjs +50 -0
- package/esm2020/components/get-validation-error-message.function.mjs +2 -2
- package/esm2020/components/input/add-array-item-dialog-data.builder.mjs +1 -1
- package/esm2020/components/input/array/array-date-input/array-date-input.component.mjs +3 -3
- package/esm2020/components/input/array/array-date-range-input/array-date-range-input.component.mjs +3 -3
- package/esm2020/components/input/array/array-date-time-input/array-date-time-input.component.mjs +3 -3
- package/esm2020/components/input/array/array-string-autocomplete-chips/array-string-autocomplete-chips.component.mjs +19 -26
- package/esm2020/components/input/array/array-string-chips-input/array-string-chips-input.component.mjs +18 -25
- package/esm2020/components/input/array/array-table.class.mjs +5 -30
- package/esm2020/components/input/base-input.component.mjs +1 -2
- package/esm2020/components/input/custom/custom.component.mjs +1 -1
- package/esm2020/components/input/date/date-range-input/date-range-input.component.mjs +2 -2
- package/esm2020/components/input/file/file-image-input/file-image-input.component.mjs +1 -1
- package/esm2020/components/input/file/file-input/dragDrop.directive.mjs +1 -2
- package/esm2020/components/input/file/file-input/file-input.component.mjs +2 -2
- package/esm2020/components/input/input.component.mjs +8 -44
- package/esm2020/components/input/string/string-autocomplete-input/string-autocomplete-input.component.mjs +2 -2
- package/esm2020/components/input/string/string-password-input/string-password-input.component.mjs +3 -3
- package/esm2020/components/table/create-dialog/create-entity-dialog.component.mjs +1 -1
- package/esm2020/components/table/edit-dialog/edit-entity-dialog.component.mjs +2 -2
- package/esm2020/components/table/table-data.builder.mjs +1 -1
- package/esm2020/components/table/table.component.mjs +5 -25
- package/esm2020/components/table/table.module.mjs +2 -2
- package/esm2020/decorators/array/array-decorator-internal.data.mjs +1 -2
- package/esm2020/decorators/base/base-property.decorator.mjs +2 -2
- package/esm2020/decorators/custom/custom-decorator-internal.data.mjs +2 -2
- package/esm2020/decorators/custom/custom-decorator.data.mjs +1 -1
- package/esm2020/decorators/custom/custom.decorator.mjs +1 -1
- package/esm2020/decorators/file/file-decorator-internal.data.mjs +1 -2
- package/esm2020/decorators/number/number-decorator.data.mjs +1 -1
- package/esm2020/decorators/string/string-decorator.data.mjs +1 -1
- package/esm2020/encapsulation/jszip.utilities.mjs +17 -0
- package/esm2020/encapsulation/lodash.utilities.mjs +75 -0
- package/esm2020/encapsulation/reflect.utilities.mjs +69 -0
- package/esm2020/mocks/placeholder-data.png.mjs +1 -1
- package/fesm2015/ngx-material-entity.mjs +152 -171
- package/fesm2015/ngx-material-entity.mjs.map +1 -1
- package/fesm2020/ngx-material-entity.mjs +146 -163
- package/fesm2020/ngx-material-entity.mjs.map +1 -1
- package/mocks/placeholder-data.png.d.ts +1 -1
- package/package.json +1 -1
- package/esm2020/capsulation/jszip.utilities.mjs +0 -17
- package/esm2020/capsulation/lodash.utilities.mjs +0 -75
- package/esm2020/capsulation/reflect.utilities.mjs +0 -69
|
@@ -25,19 +25,7 @@ export class ArrayStringChipsInputComponent extends NgxMatEntityBaseInputCompone
|
|
|
25
25
|
*/
|
|
26
26
|
addStringChipArrayValue(event) {
|
|
27
27
|
const value = (event.value || '').trim();
|
|
28
|
-
|
|
29
|
-
if (this.metadata.minLength && value.length < this.metadata.minLength) {
|
|
30
|
-
return;
|
|
31
|
-
}
|
|
32
|
-
if (this.metadata.maxLength && value.length > this.metadata.maxLength) {
|
|
33
|
-
return;
|
|
34
|
-
}
|
|
35
|
-
if (this.metadata.regex && !value.match(this.metadata.regex)) {
|
|
36
|
-
return;
|
|
37
|
-
}
|
|
38
|
-
this.propertyValue = this.propertyValue ?? [];
|
|
39
|
-
this.propertyValue.push(value);
|
|
40
|
-
}
|
|
28
|
+
this.validateAndSetPropertyValue(value);
|
|
41
29
|
event.chipInput?.clear();
|
|
42
30
|
}
|
|
43
31
|
/**
|
|
@@ -62,19 +50,24 @@ export class ArrayStringChipsInputComponent extends NgxMatEntityBaseInputCompone
|
|
|
62
50
|
*/
|
|
63
51
|
selected(event, chipsInput) {
|
|
64
52
|
const value = (event.option.viewValue || '').trim();
|
|
65
|
-
|
|
66
|
-
return;
|
|
67
|
-
}
|
|
68
|
-
if (this.metadata.maxLength && value.length > this.metadata.maxLength) {
|
|
69
|
-
return;
|
|
70
|
-
}
|
|
71
|
-
if (this.metadata.regex && !value.match(this.metadata.regex)) {
|
|
72
|
-
return;
|
|
73
|
-
}
|
|
74
|
-
this.propertyValue = this.propertyValue ?? [];
|
|
75
|
-
this.propertyValue.push(value);
|
|
53
|
+
this.validateAndSetPropertyValue(value);
|
|
76
54
|
chipsInput.value = '';
|
|
77
55
|
}
|
|
56
|
+
validateAndSetPropertyValue(value) {
|
|
57
|
+
if (value) {
|
|
58
|
+
if (this.metadata.minLength && value.length < this.metadata.minLength) {
|
|
59
|
+
return;
|
|
60
|
+
}
|
|
61
|
+
if (this.metadata.maxLength && value.length > this.metadata.maxLength) {
|
|
62
|
+
return;
|
|
63
|
+
}
|
|
64
|
+
if (this.metadata.regex && !value.match(this.metadata.regex)) {
|
|
65
|
+
return;
|
|
66
|
+
}
|
|
67
|
+
this.propertyValue = this.propertyValue ?? [];
|
|
68
|
+
this.propertyValue.push(value);
|
|
69
|
+
}
|
|
70
|
+
}
|
|
78
71
|
}
|
|
79
72
|
ArrayStringChipsInputComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.1", ngImport: i0, type: ArrayStringChipsInputComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
80
73
|
ArrayStringChipsInputComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.1", type: ArrayStringChipsInputComponent, selector: "array-string-chips-input", usesInheritance: true, ngImport: i0, template: "<mat-form-field>\n <mat-label>{{metadata.displayName}}</mat-label>\n <mat-chip-list #chipList\n (ngModelChange)=\"emitChange()\"\n [(ngModel)]=\"propertyValue\" [name]=\"key.toString()\" #model=\"ngModel\"\n [required]=\"metadata.required\"\n [disabled]=\"isReadOnly\"\n >\n <mat-chip *ngFor=\"let value of propertyValue\" (removed)=\"removeStringChipArrayValue(value)\">\n {{value}}\n <button type=\"button\" matChipRemove>\n <i class=\"{{metadata.deleteIcon}}\"></i>\n </button>\n </mat-chip>\n <input matInput\n [matChipInputFor]=\"chipList\"\n [matChipInputAddOnBlur]=\"true\"\n (matChipInputTokenEnd)=\"addStringChipArrayValue($event)\"\n [(ngModel)]=\"chipsInput\" [name]=\"key.toString()\" #chipsModel=\"ngModel\"\n [minlength]='metadata.minLength ?? null'\n [maxlength]='metadata.maxLength ?? null'\n [pattern]=\"metadata.regex ?? '[\\\\s\\\\S]*'\"\n >\n <mat-error *ngIf=\"chipsModel.errors\">{{getValidationErrorMessage(chipsModel)}}</mat-error>\n </mat-chip-list>\n <mat-error *ngIf=\"!chipsModel.errors\">{{getValidationErrorMessage(model)}}</mat-error>\n</mat-form-field>", styles: ["mat-form-field{width:100%}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.MatError, selector: "mat-error", inputs: ["id"] }, { kind: "component", type: i2.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i2.MatLabel, selector: "mat-label" }, { kind: "directive", type: i3.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "directive", type: i4.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i4.MinLengthValidator, selector: "[minlength][formControlName],[minlength][formControl],[minlength][ngModel]", inputs: ["minlength"] }, { kind: "directive", type: i4.MaxLengthValidator, selector: "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", inputs: ["maxlength"] }, { kind: "directive", type: i4.PatternValidator, selector: "[pattern][formControlName],[pattern][formControl],[pattern][ngModel]", inputs: ["pattern"] }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i5.MatChipList, selector: "mat-chip-list", inputs: ["role", "aria-describedby", "errorStateMatcher", "multiple", "compareWith", "value", "required", "placeholder", "disabled", "aria-orientation", "selectable", "tabIndex"], outputs: ["change", "valueChange"], exportAs: ["matChipList"] }, { kind: "directive", type: i5.MatChip, selector: "mat-basic-chip, [mat-basic-chip], mat-chip, [mat-chip]", inputs: ["color", "disableRipple", "tabIndex", "role", "selected", "value", "selectable", "disabled", "removable"], outputs: ["selectionChange", "destroyed", "removed"], exportAs: ["matChip"] }, { kind: "directive", type: i5.MatChipInput, selector: "input[matChipInputFor]", inputs: ["matChipInputFor", "matChipInputAddOnBlur", "matChipInputSeparatorKeyCodes", "placeholder", "id", "disabled"], outputs: ["matChipInputTokenEnd"], exportAs: ["matChipInput", "matChipInputFor"] }, { kind: "directive", type: i5.MatChipRemove, selector: "[matChipRemove]" }] });
|
|
@@ -82,4 +75,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.1", ngImpor
|
|
|
82
75
|
type: Component,
|
|
83
76
|
args: [{ selector: 'array-string-chips-input', template: "<mat-form-field>\n <mat-label>{{metadata.displayName}}</mat-label>\n <mat-chip-list #chipList\n (ngModelChange)=\"emitChange()\"\n [(ngModel)]=\"propertyValue\" [name]=\"key.toString()\" #model=\"ngModel\"\n [required]=\"metadata.required\"\n [disabled]=\"isReadOnly\"\n >\n <mat-chip *ngFor=\"let value of propertyValue\" (removed)=\"removeStringChipArrayValue(value)\">\n {{value}}\n <button type=\"button\" matChipRemove>\n <i class=\"{{metadata.deleteIcon}}\"></i>\n </button>\n </mat-chip>\n <input matInput\n [matChipInputFor]=\"chipList\"\n [matChipInputAddOnBlur]=\"true\"\n (matChipInputTokenEnd)=\"addStringChipArrayValue($event)\"\n [(ngModel)]=\"chipsInput\" [name]=\"key.toString()\" #chipsModel=\"ngModel\"\n [minlength]='metadata.minLength ?? null'\n [maxlength]='metadata.maxLength ?? null'\n [pattern]=\"metadata.regex ?? '[\\\\s\\\\S]*'\"\n >\n <mat-error *ngIf=\"chipsModel.errors\">{{getValidationErrorMessage(chipsModel)}}</mat-error>\n </mat-chip-list>\n <mat-error *ngIf=\"!chipsModel.errors\">{{getValidationErrorMessage(model)}}</mat-error>\n</mat-form-field>", styles: ["mat-form-field{width:100%}\n"] }]
|
|
84
77
|
}] });
|
|
85
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
78
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"array-string-chips-input.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-material-entity/src/components/input/array/array-string-chips-input/array-string-chips-input.component.ts","../../../../../../../projects/ngx-material-entity/src/components/input/array/array-string-chips-input/array-string-chips-input.component.html"],"names":[],"mappings":"AAAA,wCAAwC;AACxC,OAAO,EAAE,SAAS,EAAU,MAAM,eAAe,CAAC;AAKlD,OAAO,EAAE,8BAA8B,EAAE,MAAM,4BAA4B,CAAC;;;;;;;AAQ5E,MAAM,OAAO,8BACT,SAAQ,8BAAuF;IAPnG;;QASI,eAAU,GAAW,EAAE,CAAC;KA6D3B;IA3DG;;;;;;;;;;OAUG;IACH,uBAAuB,CAAC,KAAwB;QAC5C,MAAM,KAAK,GAAW,CAAC,KAAK,CAAC,KAAK,IAAI,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC;QACjD,IAAI,CAAC,2BAA2B,CAAC,KAAK,CAAC,CAAC;QACxC,KAAK,CAAC,SAAS,EAAE,KAAK,EAAE,CAAC;IAC7B,CAAC;IAED;;;;;;;;;OASG;IACH,0BAA0B,CAAC,KAAa;QACpC,IAAI,CAAC,aAAa,EAAE,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC;QACjE,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,aAAa,EAAE,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,SAAS,CAAC;IACrF,CAAC;IAED;;;;;OAKG;IACH,QAAQ,CAAC,KAAmC,EAAE,UAA4B;QACtE,MAAM,KAAK,GAAW,CAAC,KAAK,CAAC,MAAM,CAAC,SAAS,IAAI,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC;QAC5D,IAAI,CAAC,2BAA2B,CAAC,KAAK,CAAC,CAAC;QACxC,UAAU,CAAC,KAAK,GAAG,EAAE,CAAC;IAC1B,CAAC;IAEO,2BAA2B,CAAC,KAAa;QAC7C,IAAI,KAAK,EAAE;YACP,IAAI,IAAI,CAAC,QAAQ,CAAC,SAAS,IAAI,KAAK,CAAC,MAAM,GAAG,IAAI,CAAC,QAAQ,CAAC,SAAS,EAAE;gBACnE,OAAO;aACV;YACD,IAAI,IAAI,CAAC,QAAQ,CAAC,SAAS,IAAI,KAAK,CAAC,MAAM,GAAG,IAAI,CAAC,QAAQ,CAAC,SAAS,EAAE;gBACnE,OAAO;aACV;YACD,IAAI,IAAI,CAAC,QAAQ,CAAC,KAAK,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE;gBAC1D,OAAO;aACV;YACD,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,aAAa,IAAI,EAAE,CAAC;YAC9C,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;SAClC;IACL,CAAC;;2HA/DQ,8BAA8B;+GAA9B,8BAA8B,uFCd3C,ywCA0BiB;2FDZJ,8BAA8B;kBAN1C,SAAS;+BAEI,0BAA0B","sourcesContent":["/* eslint-disable jsdoc/require-jsdoc */\nimport { Component, OnInit } from '@angular/core';\nimport { DecoratorTypes } from '../../../../decorators/base/decorator-types.enum';\nimport { MatAutocompleteSelectedEvent } from '@angular/material/autocomplete';\nimport { MatChipInputEvent } from '@angular/material/chips';\nimport { BaseEntityType } from '../../../../classes/entity.model';\nimport { NgxMatEntityBaseInputComponent } from '../../base-input.component';\n\n@Component({\n    // eslint-disable-next-line @angular-eslint/component-selector\n    selector: 'array-string-chips-input',\n    templateUrl: './array-string-chips-input.component.html',\n    styleUrls: ['./array-string-chips-input.component.scss']\n})\nexport class ArrayStringChipsInputComponent<EntityType extends BaseEntityType<EntityType>>\n    extends NgxMatEntityBaseInputComponent<EntityType, DecoratorTypes.ARRAY_STRING_CHIPS, string[]> implements OnInit {\n\n    chipsInput: string = '';\n\n    /**\n     * Handles adding strings to the chipsArray.\n     * Checks validation and also creates a new array if it is undefined.\n     * This is needed because two things are validated: The array itself\n     * and the contents of the array. And we need a way to display an\n     * mat-error. As the only validation for the array is whether or not\n     * it contains values, we can set it to undefined when the last element is removed\n     * (removeStringChipArrayValue). That way we can use the \"required\" validator.\n     *\n     * @param event - The event that fires when a new chip is completed.\n     */\n    addStringChipArrayValue(event: MatChipInputEvent): void {\n        const value: string = (event.value || '').trim();\n        this.validateAndSetPropertyValue(value);\n        event.chipInput?.clear();\n    }\n\n    /**\n     * Removes the given value from the array.\n     * Sets the array to undefined if it is now empty.\n     * This is needed because two things are validated: The array itself\n     * and the contents of the array. And we need a way to display an\n     * mat-error. As the only validation for the array is whether or not\n     * it is empty, setting it to undefined here enables us to use the \"required\" validator.\n     *\n     * @param value - The string to remove from the array.\n     */\n    removeStringChipArrayValue(value: string): void {\n        this.propertyValue?.splice(this.propertyValue.indexOf(value), 1);\n        this.propertyValue = this.propertyValue?.length ? this.propertyValue : undefined;\n    }\n\n    /**\n     * Handles adding a string to the array when an autocomplete value has been selected.\n     *\n     * @param event - The autocomplete selected event.\n     * @param chipsInput - The element where the user typed the value.\n     */\n    selected(event: MatAutocompleteSelectedEvent, chipsInput: HTMLInputElement): void {\n        const value: string = (event.option.viewValue || '').trim();\n        this.validateAndSetPropertyValue(value);\n        chipsInput.value = '';\n    }\n\n    private validateAndSetPropertyValue(value: string): void {\n        if (value) {\n            if (this.metadata.minLength && value.length < this.metadata.minLength) {\n                return;\n            }\n            if (this.metadata.maxLength && value.length > this.metadata.maxLength) {\n                return;\n            }\n            if (this.metadata.regex && !value.match(this.metadata.regex)) {\n                return;\n            }\n            this.propertyValue = this.propertyValue ?? [];\n            this.propertyValue.push(value);\n        }\n    }\n}","<mat-form-field>\n    <mat-label>{{metadata.displayName}}</mat-label>\n    <mat-chip-list #chipList\n        (ngModelChange)=\"emitChange()\"\n        [(ngModel)]=\"propertyValue\" [name]=\"key.toString()\" #model=\"ngModel\"\n        [required]=\"metadata.required\"\n        [disabled]=\"isReadOnly\"\n    >\n        <mat-chip *ngFor=\"let value of propertyValue\" (removed)=\"removeStringChipArrayValue(value)\">\n            {{value}}\n            <button type=\"button\" matChipRemove>\n                <i class=\"{{metadata.deleteIcon}}\"></i>\n            </button>\n        </mat-chip>\n        <input matInput\n            [matChipInputFor]=\"chipList\"\n            [matChipInputAddOnBlur]=\"true\"\n            (matChipInputTokenEnd)=\"addStringChipArrayValue($event)\"\n            [(ngModel)]=\"chipsInput\" [name]=\"key.toString()\" #chipsModel=\"ngModel\"\n            [minlength]='metadata.minLength ?? null'\n            [maxlength]='metadata.maxLength ?? null'\n            [pattern]=\"metadata.regex ?? '[\\\\s\\\\S]*'\"\n        >\n        <mat-error *ngIf=\"chipsModel.errors\">{{getValidationErrorMessage(chipsModel)}}</mat-error>\n    </mat-chip-list>\n    <mat-error *ngIf=\"!chipsModel.errors\">{{getValidationErrorMessage(model)}}</mat-error>\n</mat-form-field>"]}
|
|
@@ -2,11 +2,12 @@
|
|
|
2
2
|
import { SelectionModel } from '@angular/cdk/collections';
|
|
3
3
|
import { MatDialog } from '@angular/material/dialog';
|
|
4
4
|
import { MatTableDataSource } from '@angular/material/table';
|
|
5
|
-
import { LodashUtilities } from '../../../
|
|
5
|
+
import { LodashUtilities } from '../../../encapsulation/lodash.utilities';
|
|
6
6
|
import { EntityUtilities } from '../../../classes/entity.utilities';
|
|
7
7
|
import { NgxMatEntityConfirmDialogComponent } from '../../confirm-dialog/confirm-dialog.component';
|
|
8
8
|
import { NgxMatEntityBaseInputComponent } from '../base-input.component';
|
|
9
9
|
import { Component } from '@angular/core';
|
|
10
|
+
import { SelectionUtilities } from '../../../classes/selection.utilities';
|
|
10
11
|
import * as i0 from "@angular/core";
|
|
11
12
|
import * as i1 from "@angular/material/dialog";
|
|
12
13
|
/**
|
|
@@ -19,6 +20,7 @@ export class ArrayTableComponent extends NgxMatEntityBaseInputComponent {
|
|
|
19
20
|
this.input = undefined;
|
|
20
21
|
this.dataSource = new MatTableDataSource();
|
|
21
22
|
this.selection = new SelectionModel(true, []);
|
|
23
|
+
this.SelectionUtilities = SelectionUtilities;
|
|
22
24
|
}
|
|
23
25
|
ngOnInit() {
|
|
24
26
|
super.ngOnInit();
|
|
@@ -31,29 +33,6 @@ export class ArrayTableComponent extends NgxMatEntityBaseInputComponent {
|
|
|
31
33
|
this.displayedColumns = this.isReadOnly ? givenDisplayColumns : ['select'].concat(givenDisplayColumns);
|
|
32
34
|
this.dataSource.data = this.propertyValue;
|
|
33
35
|
}
|
|
34
|
-
/**
|
|
35
|
-
* Toggles all array-items in the table.
|
|
36
|
-
*
|
|
37
|
-
*/
|
|
38
|
-
masterToggle() {
|
|
39
|
-
if (this.isAllSelected()) {
|
|
40
|
-
this.selection.clear();
|
|
41
|
-
}
|
|
42
|
-
else {
|
|
43
|
-
this.dataSource.data.forEach(row => this.selection.select(row));
|
|
44
|
-
}
|
|
45
|
-
}
|
|
46
|
-
/**
|
|
47
|
-
* Checks if all array-items in the table have been selected.
|
|
48
|
-
* This is needed to display the "masterToggle"-checkbox correctly.
|
|
49
|
-
*
|
|
50
|
-
* @returns Whether or not all array-items in the table have been selected.
|
|
51
|
-
*/
|
|
52
|
-
isAllSelected() {
|
|
53
|
-
const numSelected = this.selection.selected.length;
|
|
54
|
-
const numRows = this.dataSource.data.length;
|
|
55
|
-
return numSelected === numRows;
|
|
56
|
-
}
|
|
57
36
|
/**
|
|
58
37
|
* Tries to add an item to the array.
|
|
59
38
|
*/
|
|
@@ -84,11 +63,7 @@ export class ArrayTableComponent extends NgxMatEntityBaseInputComponent {
|
|
|
84
63
|
* Removes all selected entries from the entity array.
|
|
85
64
|
*/
|
|
86
65
|
remove() {
|
|
87
|
-
this.selection.
|
|
88
|
-
this.propertyValue?.splice(this.propertyValue.indexOf(s), 1);
|
|
89
|
-
});
|
|
90
|
-
this.dataSource.data = this.propertyValue ?? [];
|
|
91
|
-
this.selection.clear();
|
|
66
|
+
SelectionUtilities.remove(this.selection, this.propertyValue, this.dataSource);
|
|
92
67
|
this.emitChange();
|
|
93
68
|
}
|
|
94
69
|
}
|
|
@@ -101,4 +76,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.1", ngImpor
|
|
|
101
76
|
template: ''
|
|
102
77
|
}]
|
|
103
78
|
}], ctorParameters: function () { return [{ type: i1.MatDialog }]; } });
|
|
104
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
79
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"array-table.class.js","sourceRoot":"","sources":["../../../../../../projects/ngx-material-entity/src/components/input/array/array-table.class.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable jsdoc/require-jsdoc */\nimport { SelectionModel } from '@angular/cdk/collections';\nimport { MatDialog } from '@angular/material/dialog';\nimport { MatTableDataSource } from '@angular/material/table';\nimport { LodashUtilities } from '../../../encapsulation/lodash.utilities';\nimport { EntityUtilities } from '../../../classes/entity.utilities';\nimport { NgxMatEntityConfirmDialogComponent } from '../../confirm-dialog/confirm-dialog.component';\nimport { BaseEntityType } from '../../../classes/entity.model';\nimport { NgxMatEntityBaseInputComponent } from '../base-input.component';\nimport { DecoratorTypes } from '../../../decorators/base/decorator-types.enum';\nimport { Component, OnInit } from '@angular/core';\nimport { SelectionUtilities } from '../../../classes/selection.utilities';\n\ntype ArrayTableType = DecoratorTypes.ARRAY | DecoratorTypes.ARRAY_DATE\n    | DecoratorTypes.ARRAY_DATE_RANGE | DecoratorTypes.ARRAY_DATE_TIME;\n\n/**\n * The base component needed for all arrays that are displayed as a table.\n */\n@Component({\n    selector: 'ngx-mat-entity-array-table',\n    template: ''\n})\nexport abstract class ArrayTableComponent<ValueType, EntityType extends BaseEntityType<EntityType>, ArrayType extends ArrayTableType>\n    extends NgxMatEntityBaseInputComponent<EntityType, ArrayType, ValueType[]> implements OnInit {\n\n    input?: ValueType = undefined;\n    dataSource: MatTableDataSource<ValueType> = new MatTableDataSource();\n    selection: SelectionModel<ValueType> = new SelectionModel<ValueType>(true, []);\n    displayedColumns!: string[];\n\n    SelectionUtilities = SelectionUtilities;\n\n    constructor(private readonly matDialog: MatDialog) {\n        super();\n    }\n\n    override ngOnInit(): void {\n        super.ngOnInit();\n        this.propertyValue = this.propertyValue ?? [];\n        const givenDisplayColumns: string[] = this.metadata.displayColumns.map((v) => v.displayName);\n        if (givenDisplayColumns.find(s => s === 'select')) {\n            throw new Error(\n                `The name \"select\" for a display column is reserved.\n                Please choose a different name.`\n            );\n        }\n        this.displayedColumns = this.isReadOnly ? givenDisplayColumns : ['select'].concat(givenDisplayColumns);\n        this.dataSource.data = this.propertyValue;\n    }\n\n    /**\n     * Tries to add an item to the array.\n     */\n    add(): void {\n        if (this.input != null) {\n            if (\n                !this.metadata.allowDuplicates\n                && this.propertyValue?.find(\n                    async v => await EntityUtilities.isEqual(this.input, v, this.metadata, this.metadata.itemType)\n                ) != null\n            ) {\n                this.matDialog.open(NgxMatEntityConfirmDialogComponent, {\n                    data: this.metadata.duplicatesErrorDialog,\n                    autoFocus: false,\n                    restoreFocus: false\n                });\n                return;\n            }\n            this.propertyValue?.push(LodashUtilities.cloneDeep(this.input));\n            this.dataSource.data = this.propertyValue ?? [];\n            this.resetInput();\n            this.emitChange();\n        }\n    }\n\n    /**\n     * Is split up from the add method to override this functionality more easily.\n     */\n    protected resetInput(): void {\n        this.input = undefined;\n    }\n\n    /**\n     * Removes all selected entries from the entity array.\n     */\n    remove(): void {\n        SelectionUtilities.remove(this.selection, this.propertyValue as [], this.dataSource);\n        this.emitChange();\n    }\n}"]}
|
|
@@ -16,7 +16,6 @@ import * as i0 from "@angular/core";
|
|
|
16
16
|
* - ngOnInit: Gets the metadata for the property, be aware of this when overriding this method.
|
|
17
17
|
* - emitChange: Should be called when the input has changed. This is needed to trigger validation and dirty checks.
|
|
18
18
|
*/
|
|
19
|
-
// eslint-disable-next-line max-len
|
|
20
19
|
export class NgxMatEntityBaseInputComponent {
|
|
21
20
|
constructor() {
|
|
22
21
|
this.inputChangeEvent = new EventEmitter();
|
|
@@ -62,4 +61,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.1", ngImpor
|
|
|
62
61
|
}], inputChangeEvent: [{
|
|
63
62
|
type: Output
|
|
64
63
|
}] } });
|
|
65
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
64
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZS1pbnB1dC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtbWF0ZXJpYWwtZW50aXR5L3NyYy9jb21wb25lbnRzL2lucHV0L2Jhc2UtaW5wdXQuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBVSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFJL0UsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLGdDQUFnQyxDQUFDOztBQUVqRTs7Ozs7Ozs7Ozs7Ozs7R0FjRztBQUtILE1BQU0sT0FBZ0IsOEJBQThCO0lBSnBEO1FBb0NJLHFCQUFnQixHQUFHLElBQUksWUFBWSxFQUFRLENBQUM7S0E4Qi9DO0lBNUJHLGlEQUFpRDtJQUNqRDs7O09BR0c7SUFDSCxJQUFJLGFBQWE7UUFDYixPQUFPLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBMEIsQ0FBQztJQUMxRCxDQUFDO0lBQ0QsK0NBQStDO0lBQy9DLElBQUksYUFBYSxDQUFDLEtBQTRCO1FBQ3pDLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBMkIsR0FBRyxLQUFLLENBQUM7SUFDN0QsQ0FBQztJQU9ELFFBQVE7UUFDSixJQUFJLENBQUMsUUFBUSxHQUFHLGVBQWUsQ0FBQyxtQkFBbUIsQ0FBQyxJQUFJLENBQUMsTUFBTSxFQUFFLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUMvRSxDQUFDO0lBRUQ7O09BRUc7SUFDSCxVQUFVO1FBQ04sSUFBSSxDQUFDLGdCQUFnQixDQUFDLElBQUksRUFBRSxDQUFDO0lBQ2pDLENBQUM7OzJIQTdEaUIsOEJBQThCOytHQUE5Qiw4QkFBOEIsZ1BBRnRDLEVBQUU7MkZBRU0sOEJBQThCO2tCQUpuRCxTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSwyQkFBMkI7b0JBQ3JDLFFBQVEsRUFBRSxFQUFFO2lCQUNmOzhCQVdHLE1BQU07c0JBREwsS0FBSztnQkFPTixHQUFHO3NCQURGLEtBQUs7Z0JBT04seUJBQXlCO3NCQUR4QixLQUFLO2dCQVFOLFVBQVU7c0JBRFQsS0FBSztnQkFJTixnQkFBZ0I7c0JBRGYsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT25Jbml0LCBPdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE5nTW9kZWwgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBCYXNlRW50aXR5VHlwZSB9IGZyb20gJy4uLy4uL2NsYXNzZXMvZW50aXR5Lm1vZGVsJztcbmltcG9ydCB7IERlY29yYXRvclR5cGUsIERlY29yYXRvclR5cGVzIH0gZnJvbSAnLi4vLi4vZGVjb3JhdG9ycy9iYXNlL2RlY29yYXRvci10eXBlcy5lbnVtJztcbmltcG9ydCB7IEVudGl0eVV0aWxpdGllcyB9IGZyb20gJy4uLy4uL2NsYXNzZXMvZW50aXR5LnV0aWxpdGllcyc7XG5cbi8qKlxuICogVGhlIGFic3RyYWN0IGJhc2UgY2xhc3Mgb2YgYW55IG5neC1tYXQtZW50aXR5IGlucHV0LlxuICogRXh0ZW5kIGZyb20gdGhpcyB3aGVuIGltcGxlbWVudGluZyB5b3VyIG93biBjdXN0b20gZGVjb3JhdG9yLlxuICpcbiAqIEl0IGFscmVhZHkgcHJvdmlkZXM6XG4gKlxuICogLSBlbnRpdHk6IFRoZSBlbnRpdHkgd2hpY2ggdGhlIHByb3BlcnR5IGlzIG9uLiAodHlwZS1zYWZlIGR1ZSB0byB0aGUgR2VuZXJpYyBcIkVudGl0eVR5cGVcIilcbiAqIC0ga2V5OiBUaGUga2V5IG9mIHRoZSBwcm9wZXJ0eS4gKHR5cGUtc2FmZSBkdWUgdG8gdGhlIEdlbmVyaWMgXCJFbnRpdHlUeXBlXCIpXG4gKiAtIGdldFZhbGlkYXRpb25FcnJvck1lc3NhZ2U6IFRoZSBmdW5jdGlvbiB0aGF0IGdlbmVyYXRlcyB0aGUgZXJyb3IgbWVzc2FnZSB3aGVuIHRoZSBpbnB1dCBpcyBpbnZhbGlkLlxuICogLSBpc1JlYWRPbmx5OiBXaGV0aGVyIG9yIG5vdCB0aGUgaW5wdXQgaXMgcmVhZCBvbmx5LiBDYW4gYmUgdXNlZCB0byBkaXNhYmxlIGVsZW1lbnRzLlxuICogLSBwcm9wZXJ0eVZhbHVlOiBKdXN0IHRoZSB0eXBlZCB2ZXJzaW9uIG9mIHRoZSBwcm9wZXJ0eSwgaXRzIHRoZSBzYW1lIGFzIGVudGl0eVtrZXldLlxuICogLSBtZXRhZGF0YTogVGhlIG1ldGFkYXRhIG9mIHRoZSBwcm9wZXJ0eS4gKHR5cGUtc2FmZSBkdWUgdG8gdGhlIEdlbmVyaWMgXCJDdXN0b21NZXRhZGF0YVR5cGVcIilcbiAqIC0gbmdPbkluaXQ6IEdldHMgdGhlIG1ldGFkYXRhIGZvciB0aGUgcHJvcGVydHksIGJlIGF3YXJlIG9mIHRoaXMgd2hlbiBvdmVycmlkaW5nIHRoaXMgbWV0aG9kLlxuICogLSBlbWl0Q2hhbmdlOiBTaG91bGQgYmUgY2FsbGVkIHdoZW4gdGhlIGlucHV0IGhhcyBjaGFuZ2VkLiBUaGlzIGlzIG5lZWRlZCB0byB0cmlnZ2VyIHZhbGlkYXRpb24gYW5kIGRpcnR5IGNoZWNrcy5cbiAqL1xuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICduZ3gtbWF0LWVudGl0eS1iYXNlLWlucHV0JyxcbiAgICB0ZW1wbGF0ZTogJydcbn0pXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgTmd4TWF0RW50aXR5QmFzZUlucHV0Q29tcG9uZW50PFxuICAgIEVudGl0eVR5cGUgZXh0ZW5kcyBCYXNlRW50aXR5VHlwZTxFbnRpdHlUeXBlPixcbiAgICBUeXBlIGV4dGVuZHMgRGVjb3JhdG9yVHlwZXMsXG4gICAgVmFsdWVUeXBlLFxuICAgIEN1c3RvbU1ldGFkYXRhVHlwZSBleHRlbmRzIEJhc2VFbnRpdHlUeXBlPEN1c3RvbU1ldGFkYXRhVHlwZT4gPSB7fVxuPiBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gICAgLyoqXG4gICAgICogVGhlIGVudGl0eSB0aGF0IHRoZSBwcm9wZXJ0eSB0byBkaXNwbGF5IGFzIGFuIGlucHV0IGNvbWVzIGZyb20uXG4gICAgICovXG4gICAgQElucHV0KClcbiAgICBlbnRpdHkhOiBFbnRpdHlUeXBlO1xuXG4gICAgLyoqXG4gICAgICogVGhlIGtleSBvZiB0aGUgcHJvcGVydHkgdG8gYnVpbGQgdGhlIGlucHV0IGZvci5cbiAgICAgKi9cbiAgICBASW5wdXQoKVxuICAgIGtleSE6IGtleW9mIEVudGl0eVR5cGU7XG5cbiAgICAvKipcbiAgICAgKiBUaGUgZnVuY3Rpb24gdGhhdCBnZW5lcmF0ZXMgdGhlIGVycm9yIG1lc3NhZ2Ugd2hlbiB0aGUgaW5wdXQgaXMgaW52YWxpZC5cbiAgICAgKi9cbiAgICBASW5wdXQoKVxuICAgIGdldFZhbGlkYXRpb25FcnJvck1lc3NhZ2UhOiAobW9kZWw6IE5nTW9kZWwpID0+IHN0cmluZztcblxuICAgIC8qKlxuICAgICAqIFdoZXRoZXIgb3Igbm90IHRoZSBpbnB1dCBzaG91bGQgYmUgcmVhZG9ubHkuXG4gICAgICogSW4gdGhhdCBjYXNlIGl0IGlzIGRpc2FibGVkLCBidXQgbW9zdCBvZiB0aGUgZGlzYWJsZWQtc3R5bGluZyBpcyBvdmVycmlkZGVuLlxuICAgICAqL1xuICAgIEBJbnB1dCgpXG4gICAgaXNSZWFkT25seSE6IGJvb2xlYW47XG5cbiAgICBAT3V0cHV0KClcbiAgICBpbnB1dENoYW5nZUV2ZW50ID0gbmV3IEV2ZW50RW1pdHRlcjx2b2lkPigpO1xuXG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIGpzZG9jL3JlcXVpcmUtcmV0dXJuc1xuICAgIC8qKlxuICAgICAqIFRoZSBwcm9wZXJ0eSB2YWx1ZSBvZiBlbnRpdHlba2V5XSBjb3JyZWN0bHkgdHlwZWQuXG4gICAgICogVXNlcyBnZXR0ZXJzIGFuZCBzZXR0ZXJzIHNvIHRoYXQgaW5wdXRzIGFyZSBhbHdheXMgbGlua2VkIHRvIHRoZSBvcmlnaW5hbCB2YWx1ZS5cbiAgICAgKi9cbiAgICBnZXQgcHJvcGVydHlWYWx1ZSgpOiBWYWx1ZVR5cGUgfCB1bmRlZmluZWQge1xuICAgICAgICByZXR1cm4gdGhpcy5lbnRpdHlbdGhpcy5rZXldIGFzIFZhbHVlVHlwZSB8IHVuZGVmaW5lZDtcbiAgICB9XG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIGpzZG9jL3JlcXVpcmUtanNkb2NcbiAgICBzZXQgcHJvcGVydHlWYWx1ZSh2YWx1ZTogVmFsdWVUeXBlIHwgdW5kZWZpbmVkKSB7XG4gICAgICAgICh0aGlzLmVudGl0eVt0aGlzLmtleV0gYXMgVmFsdWVUeXBlIHwgdW5kZWZpbmVkKSA9IHZhbHVlO1xuICAgIH1cblxuICAgIC8qKlxuICAgICAqIFRoZSBtZXRhZGF0YSBvZiB0aGUgcHJvcGVydHkuXG4gICAgICovXG4gICAgbWV0YWRhdGEhOiBEZWNvcmF0b3JUeXBlPFR5cGUsIEN1c3RvbU1ldGFkYXRhVHlwZT47XG5cbiAgICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5tZXRhZGF0YSA9IEVudGl0eVV0aWxpdGllcy5nZXRQcm9wZXJ0eU1ldGFkYXRhKHRoaXMuZW50aXR5LCB0aGlzLmtleSk7XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogU2hvdWxkIGVtaXQgd2hlbiB0aGUgaW5wdXQgaGFzIGNoYW5nZWQuIFRoaXMgaXMgbmVlZGVkIHRvIHRyaWdnZXIgdmFsaWRhdGlvbiBhbmQgZGlydHkgY2hlY2tzLlxuICAgICAqL1xuICAgIGVtaXRDaGFuZ2UoKTogdm9pZCB7XG4gICAgICAgIHRoaXMuaW5wdXRDaGFuZ2VFdmVudC5lbWl0KCk7XG4gICAgfVxufSJdfQ==
|
|
@@ -23,4 +23,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.1", ngImpor
|
|
|
23
23
|
type: Component,
|
|
24
24
|
args: [{ selector: 'custom-input', template: "" }]
|
|
25
25
|
}], ctorParameters: function () { return [{ type: i0.ViewContainerRef }]; } });
|
|
26
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
26
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3VzdG9tLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1tYXRlcmlhbC1lbnRpdHkvc3JjL2NvbXBvbmVudHMvaW5wdXQvY3VzdG9tL2N1c3RvbS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtbWF0ZXJpYWwtZW50aXR5L3NyYy9jb21wb25lbnRzL2lucHV0L2N1c3RvbS9jdXN0b20uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsd0NBQXdDO0FBQ3hDLE9BQU8sRUFBRSxTQUFTLEVBQThCLGdCQUFnQixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBR3hGLE9BQU8sRUFBRSw4QkFBOEIsRUFBRSxNQUFNLHlCQUF5QixDQUFDOztBQVF6RSxNQUFNLE9BQU8sb0JBS1gsU0FBUSw4QkFBMEY7SUFJaEcsWUFBNkIsZ0JBQWtDO1FBQzNELEtBQUssRUFBRSxDQUFDO1FBRGlCLHFCQUFnQixHQUFoQixnQkFBZ0IsQ0FBa0I7SUFFL0QsQ0FBQztJQUVRLFFBQVE7UUFDYixLQUFLLENBQUMsUUFBUSxFQUFFLENBQUM7UUFDakIsSUFBSSxDQUFDLFNBQVMsR0FBRyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsZUFBZSxDQUFnQixJQUFJLENBQUMsUUFBUSxDQUFDLFNBQWdDLENBQUMsQ0FBQztRQUN0SCxJQUFJLENBQUMsU0FBUyxDQUFDLFFBQVEsQ0FBQyxNQUFNLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQztRQUM3QyxJQUFJLENBQUMsU0FBUyxDQUFDLFFBQVEsQ0FBQyxHQUFHLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FBQztRQUN2QyxJQUFJLENBQUMsU0FBUyxDQUFDLFFBQVEsQ0FBQyx5QkFBeUIsR0FBRyxJQUFJLENBQUMseUJBQXlCLENBQUM7UUFDbkYsSUFBSSxDQUFDLFNBQVMsQ0FBQyxRQUFRLENBQUMsZ0JBQWdCLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO1FBQzFFLElBQUksQ0FBQyxTQUFTLENBQUMsUUFBUSxDQUFDLFVBQVUsR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDO0lBQ3pELENBQUM7O2lIQXJCUSxvQkFBb0I7cUdBQXBCLG9CQUFvQiwyRUNaakMsRUFBQTsyRkRZYSxvQkFBb0I7a0JBTmhDLFNBQVM7K0JBRUksY0FBYyIsInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIGpzZG9jL3JlcXVpcmUtanNkb2MgKi9cbmltcG9ydCB7IENvbXBvbmVudCwgQ29tcG9uZW50UmVmLCBPbkluaXQsIFR5cGUsIFZpZXdDb250YWluZXJSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEJhc2VFbnRpdHlUeXBlIH0gZnJvbSAnLi4vLi4vLi4vY2xhc3Nlcy9lbnRpdHkubW9kZWwnO1xuaW1wb3J0IHsgRGVjb3JhdG9yVHlwZXMgfSBmcm9tICcuLi8uLi8uLi9kZWNvcmF0b3JzL2Jhc2UvZGVjb3JhdG9yLXR5cGVzLmVudW0nO1xuaW1wb3J0IHsgTmd4TWF0RW50aXR5QmFzZUlucHV0Q29tcG9uZW50IH0gZnJvbSAnLi4vYmFzZS1pbnB1dC5jb21wb25lbnQnO1xuXG5AQ29tcG9uZW50KHtcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQGFuZ3VsYXItZXNsaW50L2NvbXBvbmVudC1zZWxlY3RvclxuICAgIHNlbGVjdG9yOiAnY3VzdG9tLWlucHV0JyxcbiAgICB0ZW1wbGF0ZVVybDogJy4vY3VzdG9tLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9jdXN0b20uY29tcG9uZW50LnNjc3MnXVxufSlcbmV4cG9ydCBjbGFzcyBDdXN0b21JbnB1dENvbXBvbmVudDxcbiAgICBFbnRpdHlUeXBlIGV4dGVuZHMgQmFzZUVudGl0eVR5cGU8RW50aXR5VHlwZT4sXG4gICAgTWV0YWRhdGFUeXBlIGV4dGVuZHMgQmFzZUVudGl0eVR5cGU8TWV0YWRhdGFUeXBlPixcbiAgICBWYWx1ZVR5cGUsXG4gICAgQ29tcG9uZW50VHlwZSBleHRlbmRzIE5neE1hdEVudGl0eUJhc2VJbnB1dENvbXBvbmVudDxFbnRpdHlUeXBlLCBEZWNvcmF0b3JUeXBlcy5DVVNUT00sIFZhbHVlVHlwZSwgTWV0YWRhdGFUeXBlPlxuPiBleHRlbmRzIE5neE1hdEVudGl0eUJhc2VJbnB1dENvbXBvbmVudDxFbnRpdHlUeXBlLCBEZWNvcmF0b3JUeXBlcy5DVVNUT00sIFZhbHVlVHlwZSwgTWV0YWRhdGFUeXBlPiBpbXBsZW1lbnRzIE9uSW5pdCB7XG5cbiAgICBjb21wb25lbnQhOiBDb21wb25lbnRSZWY8Q29tcG9uZW50VHlwZT47XG5cbiAgICBjb25zdHJ1Y3Rvcihwcml2YXRlIHJlYWRvbmx5IHZpZXdDb250YWluZXJSZWY6IFZpZXdDb250YWluZXJSZWYpIHtcbiAgICAgICAgc3VwZXIoKTtcbiAgICB9XG5cbiAgICBvdmVycmlkZSBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICAgICAgc3VwZXIubmdPbkluaXQoKTtcbiAgICAgICAgdGhpcy5jb21wb25lbnQgPSB0aGlzLnZpZXdDb250YWluZXJSZWYuY3JlYXRlQ29tcG9uZW50PENvbXBvbmVudFR5cGU+KHRoaXMubWV0YWRhdGEuY29tcG9uZW50IGFzIFR5cGU8Q29tcG9uZW50VHlwZT4pO1xuICAgICAgICB0aGlzLmNvbXBvbmVudC5pbnN0YW5jZS5lbnRpdHkgPSB0aGlzLmVudGl0eTtcbiAgICAgICAgdGhpcy5jb21wb25lbnQuaW5zdGFuY2Uua2V5ID0gdGhpcy5rZXk7XG4gICAgICAgIHRoaXMuY29tcG9uZW50Lmluc3RhbmNlLmdldFZhbGlkYXRpb25FcnJvck1lc3NhZ2UgPSB0aGlzLmdldFZhbGlkYXRpb25FcnJvck1lc3NhZ2U7XG4gICAgICAgIHRoaXMuY29tcG9uZW50Lmluc3RhbmNlLmlucHV0Q2hhbmdlRXZlbnQuc3Vic2NyaWJlKHRoaXMuaW5wdXRDaGFuZ2VFdmVudCk7XG4gICAgICAgIHRoaXMuY29tcG9uZW50Lmluc3RhbmNlLmlzUmVhZE9ubHkgPSB0aGlzLmlzUmVhZE9ubHk7XG4gICAgfVxufSIsIiJdfQ==
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
/* eslint-disable jsdoc/require-jsdoc */
|
|
2
2
|
import { Component } from '@angular/core';
|
|
3
|
-
import { LodashUtilities } from '../../../../
|
|
3
|
+
import { LodashUtilities } from '../../../../encapsulation/lodash.utilities';
|
|
4
4
|
import { DateUtilities } from '../../../../classes/date.utilities';
|
|
5
5
|
import { NgxMatEntityBaseInputComponent } from '../../base-input.component';
|
|
6
6
|
import * as i0 from "@angular/core";
|
|
@@ -48,4 +48,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.1", ngImpor
|
|
|
48
48
|
type: Component,
|
|
49
49
|
args: [{ selector: 'date-range-input', template: "<mat-form-field appearance=\"standard\">\n <mat-label>{{metadata.displayName}}</mat-label>\n \n <mat-date-range-input [rangePicker]=\"picker\" [required]=\"metadata.required\" [dateFilter]=\"metadata.filter ?? defaultDateFilter\" [disabled]=\"isReadOnly\">\n <input matStartDate\n [(ngModel)]=\"dateRangeStart\"\n [name]=\"key.toString() + 'start'\"\n #startModel=\"ngModel\"\n [required]=\"metadata.required\"\n [min]=\"metadata.minStart ? metadata.minStart(dateRange.start) : undefined\"\n [max]=\"metadata.maxStart ? metadata.maxStart(dateRange.start) : undefined\"\n [placeholder]=\"metadata.placeholderStart\"\n (ngModelChange)=\"setDateRangeValues()\"\n >\n <input matEndDate\n [(ngModel)]=\"dateRangeEnd\"\n [name]=\"key.toString() + 'end'\"\n #endModel=\"ngModel\"\n [required]=\"metadata.required\"\n [min]=\"metadata.minEnd ? metadata.minEnd(dateRange.end) : undefined\"\n [max]=\"metadata.maxEnd ? metadata.maxEnd(dateRange.end) : undefined\"\n [placeholder]=\"metadata.placeholderEnd\"\n (ngModelChange)=\"setDateRangeValues()\"\n >\n </mat-date-range-input>\n <mat-datepicker-toggle matSuffix [for]=\"picker\"></mat-datepicker-toggle>\n <mat-date-range-picker #picker></mat-date-range-picker>\n\n <mat-error *ngIf=\"startModel.errors\">{{getValidationErrorMessage(startModel)}}</mat-error>\n <mat-error *ngIf=\"!startModel.errors && endModel.errors\">{{getValidationErrorMessage(endModel)}}</mat-error>\n</mat-form-field>", styles: ["mat-form-field{width:100%}\n"] }]
|
|
50
50
|
}] });
|
|
51
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
51
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZS1yYW5nZS1pbnB1dC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtbWF0ZXJpYWwtZW50aXR5L3NyYy9jb21wb25lbnRzL2lucHV0L2RhdGUvZGF0ZS1yYW5nZS1pbnB1dC9kYXRlLXJhbmdlLWlucHV0LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1tYXRlcmlhbC1lbnRpdHkvc3JjL2NvbXBvbmVudHMvaW5wdXQvZGF0ZS9kYXRlLXJhbmdlLWlucHV0L2RhdGUtcmFuZ2UtaW5wdXQuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsd0NBQXdDO0FBQ3hDLE9BQU8sRUFBRSxTQUFTLEVBQVUsTUFBTSxlQUFlLENBQUM7QUFHbEQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDRDQUE0QyxDQUFDO0FBQzdFLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQztBQUVuRSxPQUFPLEVBQUUsOEJBQThCLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQzs7Ozs7O0FBRTVFLE1BQU0sZUFBZSxHQUFjO0lBQy9CLEtBQUssRUFBRSxTQUE0QjtJQUNuQyxHQUFHLEVBQUUsU0FBNEI7SUFDakMsTUFBTSxFQUFFLFNBQVM7Q0FDcEIsQ0FBQztBQVFGLE1BQU0sT0FBTyx1QkFDVCxTQUFRLDhCQUFnRjtJQVA1Rjs7UUFhSSxzQkFBaUIsR0FBRyxhQUFhLENBQUMsaUJBQWlCLENBQUM7S0E4QnZEO0lBNUJZLFFBQVE7UUFDYixLQUFLLENBQUMsUUFBUSxFQUFFLENBQUM7UUFDakIsSUFBSSxDQUFDLFNBQVMsR0FBRyxlQUFlLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsSUFBSSxlQUFlLENBQUM7UUFDbEYsSUFBSSxDQUFDLGNBQWMsR0FBRyxJQUFJLElBQUksQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQ3JELElBQUksQ0FBQyxZQUFZLEdBQUcsSUFBSSxJQUFJLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUNqRCxJQUFJLENBQUMsa0JBQWtCLEVBQUUsQ0FBQztJQUM5QixDQUFDO0lBRUQ7O09BRUc7SUFDSCxrQkFBa0I7UUFDZCxJQUFJLElBQUksQ0FBQyxjQUFjLElBQUksSUFBSSxDQUFDLFlBQVksRUFBRTtZQUMxQyxJQUFJLENBQUMsU0FBUyxDQUFDLEtBQUssR0FBRyxJQUFJLElBQUksQ0FBQyxJQUFJLENBQUMsY0FBYyxDQUFDLENBQUM7WUFDckQsSUFBSSxDQUFDLFNBQVMsQ0FBQyxHQUFHLEdBQUcsSUFBSSxJQUFJLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxDQUFDO1lBQ2pELE1BQU0sTUFBTSxHQUFXLGFBQWEsQ0FBQyxlQUFlLENBQ2hELElBQUksSUFBSSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLEVBQzlCLElBQUksSUFBSSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUFDLEVBQzVCLElBQUksQ0FBQyxRQUFRLENBQUMsTUFBTSxDQUN2QixDQUFDO1lBQ0YsSUFBSSxDQUFDLFNBQVMsQ0FBQyxNQUFNLEdBQUcsTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUM7U0FDOUQ7YUFDSTtZQUNELElBQUksQ0FBQyxTQUFTLENBQUMsTUFBTSxHQUFHLFNBQVMsQ0FBQztTQUNyQztRQUNELElBQUksQ0FBQyxhQUFhLEdBQUcsSUFBSSxDQUFDLFNBQVMsQ0FBQztRQUNwQyxJQUFJLENBQUMsVUFBVSxFQUFFLENBQUM7SUFDdEIsQ0FBQzs7b0hBcENRLHVCQUF1Qjt3R0FBdkIsdUJBQXVCLCtFQ3JCcEMsZ29EQThCaUI7MkZEVEosdUJBQXVCO2tCQU5uQyxTQUFTOytCQUVJLGtCQUFrQiIsInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIGpzZG9jL3JlcXVpcmUtanNkb2MgKi9cbmltcG9ydCB7IENvbXBvbmVudCwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBEZWNvcmF0b3JUeXBlcyB9IGZyb20gJy4uLy4uLy4uLy4uL2RlY29yYXRvcnMvYmFzZS9kZWNvcmF0b3ItdHlwZXMuZW51bSc7XG5pbXBvcnQgeyBEYXRlUmFuZ2UgfSBmcm9tICcuLi8uLi8uLi8uLi9kZWNvcmF0b3JzL2RhdGUvZGF0ZS1kZWNvcmF0b3IuZGF0YSc7XG5pbXBvcnQgeyBMb2Rhc2hVdGlsaXRpZXMgfSBmcm9tICcuLi8uLi8uLi8uLi9lbmNhcHN1bGF0aW9uL2xvZGFzaC51dGlsaXRpZXMnO1xuaW1wb3J0IHsgRGF0ZVV0aWxpdGllcyB9IGZyb20gJy4uLy4uLy4uLy4uL2NsYXNzZXMvZGF0ZS51dGlsaXRpZXMnO1xuaW1wb3J0IHsgQmFzZUVudGl0eVR5cGUgfSBmcm9tICcuLi8uLi8uLi8uLi9jbGFzc2VzL2VudGl0eS5tb2RlbCc7XG5pbXBvcnQgeyBOZ3hNYXRFbnRpdHlCYXNlSW5wdXRDb21wb25lbnQgfSBmcm9tICcuLi8uLi9iYXNlLWlucHV0LmNvbXBvbmVudCc7XG5cbmNvbnN0IEVNUFRZX0RBVEVSQU5HRTogRGF0ZVJhbmdlID0ge1xuICAgIHN0YXJ0OiB1bmRlZmluZWQgYXMgdW5rbm93biBhcyBEYXRlLFxuICAgIGVuZDogdW5kZWZpbmVkIGFzIHVua25vd24gYXMgRGF0ZSxcbiAgICB2YWx1ZXM6IHVuZGVmaW5lZFxufTtcblxuQENvbXBvbmVudCh7XG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEBhbmd1bGFyLWVzbGludC9jb21wb25lbnQtc2VsZWN0b3JcbiAgICBzZWxlY3RvcjogJ2RhdGUtcmFuZ2UtaW5wdXQnLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9kYXRlLXJhbmdlLWlucHV0LmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9kYXRlLXJhbmdlLWlucHV0LmNvbXBvbmVudC5zY3NzJ11cbn0pXG5leHBvcnQgY2xhc3MgRGF0ZVJhbmdlSW5wdXRDb21wb25lbnQ8RW50aXR5VHlwZSBleHRlbmRzIEJhc2VFbnRpdHlUeXBlPEVudGl0eVR5cGU+PlxuICAgIGV4dGVuZHMgTmd4TWF0RW50aXR5QmFzZUlucHV0Q29tcG9uZW50PEVudGl0eVR5cGUsIERlY29yYXRvclR5cGVzLkRBVEVfUkFOR0UsIERhdGVSYW5nZT4gaW1wbGVtZW50cyBPbkluaXQge1xuXG4gICAgZGF0ZVJhbmdlITogRGF0ZVJhbmdlO1xuICAgIGRhdGVSYW5nZVN0YXJ0PzogRGF0ZTtcbiAgICBkYXRlUmFuZ2VFbmQ/OiBEYXRlO1xuXG4gICAgZGVmYXVsdERhdGVGaWx0ZXIgPSBEYXRlVXRpbGl0aWVzLmRlZmF1bHREYXRlRmlsdGVyO1xuXG4gICAgb3ZlcnJpZGUgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgICAgIHN1cGVyLm5nT25Jbml0KCk7XG4gICAgICAgIHRoaXMuZGF0ZVJhbmdlID0gTG9kYXNoVXRpbGl0aWVzLmNsb25lRGVlcCh0aGlzLnByb3BlcnR5VmFsdWUpID8/IEVNUFRZX0RBVEVSQU5HRTtcbiAgICAgICAgdGhpcy5kYXRlUmFuZ2VTdGFydCA9IG5ldyBEYXRlKHRoaXMuZGF0ZVJhbmdlLnN0YXJ0KTtcbiAgICAgICAgdGhpcy5kYXRlUmFuZ2VFbmQgPSBuZXcgRGF0ZSh0aGlzLmRhdGVSYW5nZS5lbmQpO1xuICAgICAgICB0aGlzLnNldERhdGVSYW5nZVZhbHVlcygpO1xuICAgIH1cblxuICAgIC8qKlxuICAgICAqIFVwZGF0ZXMgdGhlIGRhdGUgcmFuZ2UgdmFsdWVzIGJhc2VkIG9uIHRoZSBzdGFydCBhbmQgZW5kIGRhdGUuXG4gICAgICovXG4gICAgc2V0RGF0ZVJhbmdlVmFsdWVzKCk6IHZvaWQge1xuICAgICAgICBpZiAodGhpcy5kYXRlUmFuZ2VTdGFydCAmJiB0aGlzLmRhdGVSYW5nZUVuZCkge1xuICAgICAgICAgICAgdGhpcy5kYXRlUmFuZ2Uuc3RhcnQgPSBuZXcgRGF0ZSh0aGlzLmRhdGVSYW5nZVN0YXJ0KTtcbiAgICAgICAgICAgIHRoaXMuZGF0ZVJhbmdlLmVuZCA9IG5ldyBEYXRlKHRoaXMuZGF0ZVJhbmdlRW5kKTtcbiAgICAgICAgICAgIGNvbnN0IHZhbHVlczogRGF0ZVtdID0gRGF0ZVV0aWxpdGllcy5nZXREYXRlc0JldHdlZW4oXG4gICAgICAgICAgICAgICAgbmV3IERhdGUodGhpcy5kYXRlUmFuZ2Uuc3RhcnQpLFxuICAgICAgICAgICAgICAgIG5ldyBEYXRlKHRoaXMuZGF0ZVJhbmdlLmVuZCksXG4gICAgICAgICAgICAgICAgdGhpcy5tZXRhZGF0YS5maWx0ZXJcbiAgICAgICAgICAgICk7XG4gICAgICAgICAgICB0aGlzLmRhdGVSYW5nZS52YWx1ZXMgPSB2YWx1ZXMubGVuZ3RoID8gdmFsdWVzIDogdW5kZWZpbmVkO1xuICAgICAgICB9XG4gICAgICAgIGVsc2Uge1xuICAgICAgICAgICAgdGhpcy5kYXRlUmFuZ2UudmFsdWVzID0gdW5kZWZpbmVkO1xuICAgICAgICB9XG4gICAgICAgIHRoaXMucHJvcGVydHlWYWx1ZSA9IHRoaXMuZGF0ZVJhbmdlO1xuICAgICAgICB0aGlzLmVtaXRDaGFuZ2UoKTtcbiAgICB9XG59IiwiPG1hdC1mb3JtLWZpZWxkIGFwcGVhcmFuY2U9XCJzdGFuZGFyZFwiPlxuICAgIDxtYXQtbGFiZWw+e3ttZXRhZGF0YS5kaXNwbGF5TmFtZX19PC9tYXQtbGFiZWw+XG4gICAgXG4gICAgPG1hdC1kYXRlLXJhbmdlLWlucHV0IFtyYW5nZVBpY2tlcl09XCJwaWNrZXJcIiBbcmVxdWlyZWRdPVwibWV0YWRhdGEucmVxdWlyZWRcIiBbZGF0ZUZpbHRlcl09XCJtZXRhZGF0YS5maWx0ZXIgPz8gZGVmYXVsdERhdGVGaWx0ZXJcIiBbZGlzYWJsZWRdPVwiaXNSZWFkT25seVwiPlxuICAgICAgICA8aW5wdXQgbWF0U3RhcnREYXRlXG4gICAgICAgICAgICBbKG5nTW9kZWwpXT1cImRhdGVSYW5nZVN0YXJ0XCJcbiAgICAgICAgICAgIFtuYW1lXT1cImtleS50b1N0cmluZygpICsgJ3N0YXJ0J1wiXG4gICAgICAgICAgICAjc3RhcnRNb2RlbD1cIm5nTW9kZWxcIlxuICAgICAgICAgICAgW3JlcXVpcmVkXT1cIm1ldGFkYXRhLnJlcXVpcmVkXCJcbiAgICAgICAgICAgIFttaW5dPVwibWV0YWRhdGEubWluU3RhcnQgPyBtZXRhZGF0YS5taW5TdGFydChkYXRlUmFuZ2Uuc3RhcnQpIDogdW5kZWZpbmVkXCJcbiAgICAgICAgICAgIFttYXhdPVwibWV0YWRhdGEubWF4U3RhcnQgPyBtZXRhZGF0YS5tYXhTdGFydChkYXRlUmFuZ2Uuc3RhcnQpIDogdW5kZWZpbmVkXCJcbiAgICAgICAgICAgIFtwbGFjZWhvbGRlcl09XCJtZXRhZGF0YS5wbGFjZWhvbGRlclN0YXJ0XCJcbiAgICAgICAgICAgIChuZ01vZGVsQ2hhbmdlKT1cInNldERhdGVSYW5nZVZhbHVlcygpXCJcbiAgICAgICAgPlxuICAgICAgICA8aW5wdXQgbWF0RW5kRGF0ZVxuICAgICAgICAgICAgWyhuZ01vZGVsKV09XCJkYXRlUmFuZ2VFbmRcIlxuICAgICAgICAgICAgW25hbWVdPVwia2V5LnRvU3RyaW5nKCkgKyAnZW5kJ1wiXG4gICAgICAgICAgICAjZW5kTW9kZWw9XCJuZ01vZGVsXCJcbiAgICAgICAgICAgIFtyZXF1aXJlZF09XCJtZXRhZGF0YS5yZXF1aXJlZFwiXG4gICAgICAgICAgICBbbWluXT1cIm1ldGFkYXRhLm1pbkVuZCA/IG1ldGFkYXRhLm1pbkVuZChkYXRlUmFuZ2UuZW5kKSA6IHVuZGVmaW5lZFwiXG4gICAgICAgICAgICBbbWF4XT1cIm1ldGFkYXRhLm1heEVuZCA/IG1ldGFkYXRhLm1heEVuZChkYXRlUmFuZ2UuZW5kKSA6IHVuZGVmaW5lZFwiXG4gICAgICAgICAgICBbcGxhY2Vob2xkZXJdPVwibWV0YWRhdGEucGxhY2Vob2xkZXJFbmRcIlxuICAgICAgICAgICAgKG5nTW9kZWxDaGFuZ2UpPVwic2V0RGF0ZVJhbmdlVmFsdWVzKClcIlxuICAgICAgICA+XG4gICAgPC9tYXQtZGF0ZS1yYW5nZS1pbnB1dD5cbiAgICA8bWF0LWRhdGVwaWNrZXItdG9nZ2xlIG1hdFN1ZmZpeCBbZm9yXT1cInBpY2tlclwiPjwvbWF0LWRhdGVwaWNrZXItdG9nZ2xlPlxuICAgIDxtYXQtZGF0ZS1yYW5nZS1waWNrZXIgI3BpY2tlcj48L21hdC1kYXRlLXJhbmdlLXBpY2tlcj5cblxuICAgIDxtYXQtZXJyb3IgKm5nSWY9XCJzdGFydE1vZGVsLmVycm9yc1wiPnt7Z2V0VmFsaWRhdGlvbkVycm9yTWVzc2FnZShzdGFydE1vZGVsKX19PC9tYXQtZXJyb3I+XG4gICAgPG1hdC1lcnJvciAqbmdJZj1cIiFzdGFydE1vZGVsLmVycm9ycyAmJiBlbmRNb2RlbC5lcnJvcnNcIj57e2dldFZhbGlkYXRpb25FcnJvck1lc3NhZ2UoZW5kTW9kZWwpfX08L21hdC1lcnJvcj5cbjwvbWF0LWZvcm0tZmllbGQ+Il19
|
|
@@ -81,4 +81,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.1", ngImpor
|
|
|
81
81
|
type: Component,
|
|
82
82
|
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 >\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 >\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"] }]
|
|
83
83
|
}] });
|
|
84
|
-
//# 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 { FileUtilities } from '../../../../classes/file.utilities';\nimport { DecoratorTypes } from '../../../../decorators/base/decorator-types.enum';\nimport { FileData } from '../../../../decorators/file/file-decorator.data';\nimport { placeholder } from '../../../../mocks/placeholder-data.png';\nimport { BaseEntityType } from '../../../../classes/entity.model';\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 = FileUtilities;\n\n    singlePreviewImage?: string;\n    multiPreviewImages?: string[];\n    imageIndex: number = 0;\n    placeHolder = 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 = this.propertyValue as FileData[] | undefined;\n        const previewImages: string[] = [];\n        if (multiFileData?.length) {\n            for (let i = 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    >\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    >\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>"]}
|
|
84
|
+
//# 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 { FileUtilities } from '../../../../classes/file.utilities';\nimport { DecoratorTypes } from '../../../../decorators/base/decorator-types.enum';\nimport { FileData } from '../../../../decorators/file/file-decorator.data';\nimport { placeholder } from '../../../../mocks/placeholder-data.png';\nimport { BaseEntityType } from '../../../../classes/entity.model';\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 = FileUtilities;\n\n    singlePreviewImage?: string;\n    multiPreviewImages?: string[];\n    imageIndex: number = 0;\n    placeHolder = 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    >\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    >\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>"]}
|
|
@@ -46,7 +46,6 @@ DragDropDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", vers
|
|
|
46
46
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.1", ngImport: i0, type: DragDropDirective, decorators: [{
|
|
47
47
|
type: Directive,
|
|
48
48
|
args: [{
|
|
49
|
-
// eslint-disable-next-line @angular-eslint/directive-selector
|
|
50
49
|
selector: '[dragDrop]'
|
|
51
50
|
}]
|
|
52
51
|
}], ctorParameters: function () { return []; }, propDecorators: { files: [{
|
|
@@ -61,4 +60,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.1", ngImpor
|
|
|
61
60
|
type: HostListener,
|
|
62
61
|
args: ['drop', ['$event']]
|
|
63
62
|
}] } });
|
|
64
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
63
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJhZ0Ryb3AuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LW1hdGVyaWFsLWVudGl0eS9zcmMvY29tcG9uZW50cy9pbnB1dC9maWxlL2ZpbGUtaW5wdXQvZHJhZ0Ryb3AuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLFlBQVksRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBRTlFOztHQUVHO0FBSUgsTUFBTSxPQUFPLGlCQUFpQjtJQU8xQjtRQU5BOztXQUVHO1FBRUgsVUFBSyxHQUF5QixJQUFJLFlBQVksRUFBVSxDQUFDO0lBRXpDLENBQUM7SUFFakI7Ozs7T0FJRztJQUVILFVBQVUsQ0FBQyxHQUFjO1FBQ3JCLEdBQUcsQ0FBQyxjQUFjLEVBQUUsQ0FBQztRQUNyQixHQUFHLENBQUMsZUFBZSxFQUFFLENBQUM7SUFDMUIsQ0FBQztJQUVEOzs7O09BSUc7SUFFSCxXQUFXLENBQUMsR0FBYztRQUN0QixHQUFHLENBQUMsY0FBYyxFQUFFLENBQUM7UUFDckIsR0FBRyxDQUFDLGVBQWUsRUFBRSxDQUFDO0lBQzFCLENBQUM7SUFFRDs7OztPQUlHO0lBRUgsTUFBTSxDQUFDLEdBQWM7UUFDakIsR0FBRyxDQUFDLGNBQWMsRUFBRSxDQUFDO1FBQ3JCLEdBQUcsQ0FBQyxlQUFlLEVBQUUsQ0FBQztRQUN0QixJQUFJLEdBQUcsQ0FBQyxZQUFZLElBQUksR0FBRyxDQUFDLFlBQVksQ0FBQyxLQUFLLENBQUMsTUFBTSxHQUFHLENBQUMsRUFBRTtZQUN2RCxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxZQUFZLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQztTQUN2RDtJQUNMLENBQUM7OzhHQTNDUSxpQkFBaUI7a0dBQWpCLGlCQUFpQjsyRkFBakIsaUJBQWlCO2tCQUg3QixTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSxZQUFZO2lCQUN6QjswRUFNRyxLQUFLO3NCQURKLE1BQU07Z0JBV1AsVUFBVTtzQkFEVCxZQUFZO3VCQUFDLFVBQVUsRUFBRSxDQUFDLFFBQVEsQ0FBQztnQkFZcEMsV0FBVztzQkFEVixZQUFZO3VCQUFDLFdBQVcsRUFBRSxDQUFDLFFBQVEsQ0FBQztnQkFZckMsTUFBTTtzQkFETCxZQUFZO3VCQUFDLE1BQU0sRUFBRSxDQUFDLFFBQVEsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgRXZlbnRFbWl0dGVyLCBIb3N0TGlzdGVuZXIsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG4vKipcbiAqIEFkZHMgZHJhZyBhbmQgZHJvcCBmdW5jdGlvbmFsaXR5IHRvIGFuIGVsZW1lbnQuXG4gKi9cbkBEaXJlY3RpdmUoe1xuICAgIHNlbGVjdG9yOiAnW2RyYWdEcm9wXSdcbn0pXG5leHBvcnQgY2xhc3MgRHJhZ0Ryb3BEaXJlY3RpdmUge1xuICAgIC8qKlxuICAgICAqIEVtaXRzIHRoZSBkcm9wcGVkIGZpbGVzIHRvIHRoZSBwYXJlbnQuXG4gICAgICovXG4gICAgQE91dHB1dCgpXG4gICAgZmlsZXM6IEV2ZW50RW1pdHRlcjxGaWxlW10+ID0gbmV3IEV2ZW50RW1pdHRlcjxGaWxlW10+KCk7XG5cbiAgICBjb25zdHJ1Y3RvcigpIHsgfVxuXG4gICAgLyoqXG4gICAgICogUHJldmVudHMgdGhlIGV2ZW50IGRlZmF1bHQuXG4gICAgICpcbiAgICAgKiBAcGFyYW0gZXZ0IC0gVGhlIEV2ZW50IHdoZW4gZHJhZ2dlZCBmaWxlcyBob3ZlciBvdmVyIHRoZSBwYXJlbnQuXG4gICAgICovXG4gICAgQEhvc3RMaXN0ZW5lcignZHJhZ292ZXInLCBbJyRldmVudCddKVxuICAgIG9uRHJhZ092ZXIoZXZ0OiBEcmFnRXZlbnQpOiB2b2lkIHtcbiAgICAgICAgZXZ0LnByZXZlbnREZWZhdWx0KCk7XG4gICAgICAgIGV2dC5zdG9wUHJvcGFnYXRpb24oKTtcbiAgICB9XG5cbiAgICAvKipcbiAgICAgKiBQcmV2ZW50cyB0aGUgZXZlbnQgZGVmYXVsdC5cbiAgICAgKlxuICAgICAqIEBwYXJhbSBldnQgLSBUaGUgRXZlbnQgd2hlbiBkcmFnZ2VkIGZpbGVzIGxlYXZlIHRoZSBwYXJlbnQuXG4gICAgICovXG4gICAgQEhvc3RMaXN0ZW5lcignZHJhZ2xlYXZlJywgWyckZXZlbnQnXSlcbiAgICBvbkRyYWdMZWF2ZShldnQ6IERyYWdFdmVudCk6IHZvaWQge1xuICAgICAgICBldnQucHJldmVudERlZmF1bHQoKTtcbiAgICAgICAgZXZ0LnN0b3BQcm9wYWdhdGlvbigpO1xuICAgIH1cblxuICAgIC8qKlxuICAgICAqIFByZXZlbnRzIHRoZSBldmVudCBkZWZhdWx0IGFuZCBlbWl0cyB0aGUgZHJvcHBlZCBmaWxlcyB3aXRoIHRoZSBvdXRwdXQuXG4gICAgICpcbiAgICAgKiBAcGFyYW0gZXZ0IC0gVGhlIEV2ZW50IHdoZW4gZmlsZXMgYXJlIGRyb3BwZWQuXG4gICAgICovXG4gICAgQEhvc3RMaXN0ZW5lcignZHJvcCcsIFsnJGV2ZW50J10pXG4gICAgb25Ecm9wKGV2dDogRHJhZ0V2ZW50KTogdm9pZCB7XG4gICAgICAgIGV2dC5wcmV2ZW50RGVmYXVsdCgpO1xuICAgICAgICBldnQuc3RvcFByb3BhZ2F0aW9uKCk7XG4gICAgICAgIGlmIChldnQuZGF0YVRyYW5zZmVyICYmIGV2dC5kYXRhVHJhbnNmZXIuZmlsZXMubGVuZ3RoID4gMCkge1xuICAgICAgICAgICAgdGhpcy5maWxlcy5lbWl0KEFycmF5LmZyb20oZXZ0LmRhdGFUcmFuc2Zlci5maWxlcykpO1xuICAgICAgICB9XG4gICAgfVxufSJdfQ==
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
/* eslint-disable jsdoc/require-jsdoc */
|
|
2
2
|
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
3
3
|
import { FileUtilities } from '../../../../classes/file.utilities';
|
|
4
|
-
import { LodashUtilities } from '../../../../
|
|
4
|
+
import { LodashUtilities } from '../../../../encapsulation/lodash.utilities';
|
|
5
5
|
import { MatDialog } from '@angular/material/dialog';
|
|
6
6
|
import { NgxMatEntityConfirmDialogComponent } from '../../../confirm-dialog/confirm-dialog.component';
|
|
7
7
|
import * as i0 from "@angular/core";
|
|
@@ -176,4 +176,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.1", ngImpor
|
|
|
176
176
|
}], fileDataChangeEvent: [{
|
|
177
177
|
type: Output
|
|
178
178
|
}] } });
|
|
179
|
-
//# 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 { DefaultFileDecoratorConfigInternal, FileDataWithFile, ImageFileDecoratorConfigInternal } from '../../../../decorators/file/file-decorator-internal.data';\nimport { FileUtilities } from '../../../../classes/file.utilities';\nimport { FileData } from '../../../../decorators/file/file-decorator.data';\nimport { LodashUtilities } from '../../../../capsulation/lodash.utilities';\nimport { MatDialog } from '@angular/material/dialog';\nimport { NgxMatEntityConfirmDialogComponent } from '../../../confirm-dialog/confirm-dialog.component';\nimport { BaseEntityType } from '../../../../classes/entity.model';\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    filenames?: string[];\n\n    FileUtilities = FileUtilities;\n\n    @Input()\n    propertyValue!: FileData | FileData[] | undefined;\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 = 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 = (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 = 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.metadata.multiple) {\n            this.filenames?.splice(this.filenames.indexOf(name), 1);\n            if (!this.filenames?.length) {\n                this.filenames = undefined;\n            }\n            const fileDataToRemove = (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 = (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 = (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            void FileUtilities.downloadMultipleFiles(this.metadata.displayName, (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-list #chipList\n        [(ngModel)]=\"filenames\"\n        name=\"file\"\n        #model=\"ngModel\"\n        [required]=\"metadata.required\"\n        [disabled]=\"isReadOnly\"\n    >\n        <mat-chip *ngFor=\"let name of filenames\" (removed)=\"removeFile(name)\">\n            {{name}}\n            <button type=\"button\" class=\"mat-chip-remove mat-chip-trailing-icon ngx-mat-grey\" (click)=\"downloadFile(name)\">\n                <i class=\"fas fa-download\"></i>\n            </button>\n            <button type=\"button\" matChipRemove (click)=\"chipList._markAsTouched()\">\n                <i class=\"{{metadata.deleteIcon}}\"></i>\n            </button>\n        </mat-chip>\n        <mat-chip class=\"download-all-button\" *ngIf=\"downloadAllEnabled()\" (click)=\"downloadAll()\">\n            {{metadata.downloadAllButtonLabel}}\n            <span class=\"mat-chip-remove mat-chip-trailing-icon ngx-mat-grey\">\n                <i class=\"fas fa-file-zipper\"></i>\n            </span>\n        </mat-chip>\n        <input [matChipInputFor]=\"chipList\" [readonly]=\"true\" hidden>\n    </mat-chip-list>\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>"]}
|
|
179
|
+
//# 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 { DefaultFileDecoratorConfigInternal, FileDataWithFile, ImageFileDecoratorConfigInternal } from '../../../../decorators/file/file-decorator-internal.data';\nimport { FileUtilities } from '../../../../classes/file.utilities';\nimport { FileData } from '../../../../decorators/file/file-decorator.data';\nimport { LodashUtilities } from '../../../../encapsulation/lodash.utilities';\nimport { MatDialog } from '@angular/material/dialog';\nimport { NgxMatEntityConfirmDialogComponent } from '../../../confirm-dialog/confirm-dialog.component';\nimport { BaseEntityType } from '../../../../classes/entity.model';\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    filenames?: string[];\n\n    FileUtilities = FileUtilities;\n\n    @Input()\n    propertyValue!: FileData | FileData[] | undefined;\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 = 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.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            void FileUtilities.downloadMultipleFiles(this.metadata.displayName, (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-list #chipList\n        [(ngModel)]=\"filenames\"\n        name=\"file\"\n        #model=\"ngModel\"\n        [required]=\"metadata.required\"\n        [disabled]=\"isReadOnly\"\n    >\n        <mat-chip *ngFor=\"let name of filenames\" (removed)=\"removeFile(name)\">\n            {{name}}\n            <button type=\"button\" class=\"mat-chip-remove mat-chip-trailing-icon ngx-mat-grey\" (click)=\"downloadFile(name)\">\n                <i class=\"fas fa-download\"></i>\n            </button>\n            <button type=\"button\" matChipRemove (click)=\"chipList._markAsTouched()\">\n                <i class=\"{{metadata.deleteIcon}}\"></i>\n            </button>\n        </mat-chip>\n        <mat-chip class=\"download-all-button\" *ngIf=\"downloadAllEnabled()\" (click)=\"downloadAll()\">\n            {{metadata.downloadAllButtonLabel}}\n            <span class=\"mat-chip-remove mat-chip-trailing-icon ngx-mat-grey\">\n                <i class=\"fas fa-file-zipper\"></i>\n            </span>\n        </mat-chip>\n        <input [matChipInputFor]=\"chipList\" [readonly]=\"true\" hidden>\n    </mat-chip-list>\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>"]}
|