ngx-material-entity 16.0.1 → 16.0.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/components/input/input.component.d.ts +27 -2
- package/components/input/input.module.d.ts +2 -1
- package/esm2022/components/input/array/array-string-chips-input/array-string-chips-input.component.mjs +2 -2
- package/esm2022/components/input/input.component.mjs +90 -32
- package/esm2022/components/input/input.module.mjs +8 -4
- package/esm2022/components/table/table.component.mjs +8 -6
- package/fesm2022/ngx-material-entity.mjs +79 -18
- package/fesm2022/ngx-material-entity.mjs.map +1 -1
- package/package.json +1 -1
|
@@ -19,6 +19,7 @@ import { DateUtilities } from '../../utilities/date.utilities';
|
|
|
19
19
|
import { EntityTab, EntityUtilities } from '../../utilities/entity.utilities';
|
|
20
20
|
import { SelectionUtilities } from '../../utilities/selection.utilities';
|
|
21
21
|
import { CreateDialogDataInternal } from '../table/create-dialog/create-dialog-data.builder';
|
|
22
|
+
import { EditActionInternal } from '../table/edit-dialog/edit-data.builder';
|
|
22
23
|
import { DisplayColumn } from '../table/table-data';
|
|
23
24
|
import { BaseTableActionInternal, TableActionInternal } from '../table/table-data.builder';
|
|
24
25
|
import * as i0 from "@angular/core";
|
|
@@ -107,8 +108,18 @@ export declare class NgxMatEntityInputComponent<EntityType extends BaseEntityTyp
|
|
|
107
108
|
editArrayItemDialogData: EditArrayItemDialogDataInternal<EntityType>;
|
|
108
109
|
metadataHasMany: HasManyDecoratorConfigInternal<EntityType, EntityType>;
|
|
109
110
|
hasManyIsLoading: boolean;
|
|
110
|
-
|
|
111
|
-
|
|
111
|
+
/**
|
|
112
|
+
* A setter for the has many paginator.
|
|
113
|
+
* Is needed because the paginator is inside a switch case,
|
|
114
|
+
* which means that at ngOnInit it can't be initialized.
|
|
115
|
+
*/
|
|
116
|
+
set hasManyPaginator(paginator: MatPaginator);
|
|
117
|
+
/**
|
|
118
|
+
* A setter for the has many sort.
|
|
119
|
+
* Is needed because the sort is inside a switch case,
|
|
120
|
+
* which means that at ngOnInit it can't be initialized.
|
|
121
|
+
*/
|
|
122
|
+
set hasManySort(sort: MatSort);
|
|
112
123
|
hasManyFilter: string;
|
|
113
124
|
displayedHasManyColumns: string[];
|
|
114
125
|
hasManyDataSource: MatTableDataSource<EntityType>;
|
|
@@ -202,6 +213,20 @@ export declare class NgxMatEntityInputComponent<EntityType extends BaseEntityTyp
|
|
|
202
213
|
* @returns True when the user can delete the provided entity and false otherwise.
|
|
203
214
|
*/
|
|
204
215
|
hasManyAllowDelete(entity: EntityType): boolean;
|
|
216
|
+
/**
|
|
217
|
+
* Checks if an EditAction is disabled (e.g. Because the current entry doesn't fullfil the requirements).
|
|
218
|
+
*
|
|
219
|
+
* @param action - The EditAction to check.
|
|
220
|
+
* @returns Whether or not the Action can be used.
|
|
221
|
+
*/
|
|
222
|
+
hasManyEditActionDisabled(action: EditActionInternal<EntityType>): boolean;
|
|
223
|
+
/**
|
|
224
|
+
* Runs the edit action on the entity.
|
|
225
|
+
*
|
|
226
|
+
* @param action - The action to run.
|
|
227
|
+
*/
|
|
228
|
+
hasManyRunEditAction(action: EditActionInternal<EntityType>): void;
|
|
229
|
+
private confirmHasManyRunEditAction;
|
|
205
230
|
private editHasManyDefaultPage;
|
|
206
231
|
private editHasManyDefaultDialog;
|
|
207
232
|
/**
|
|
@@ -45,8 +45,9 @@ import * as i43 from "@angular/material/menu";
|
|
|
45
45
|
import * as i44 from "@angular/material/progress-spinner";
|
|
46
46
|
import * as i45 from "@angular/material/paginator";
|
|
47
47
|
import * as i46 from "../table/display-column-value/display-column-value.component";
|
|
48
|
+
import * as i47 from "@angular/material/sort";
|
|
48
49
|
export declare class NgxMatEntityInputModule {
|
|
49
50
|
static ɵfac: i0.ɵɵFactoryDeclaration<NgxMatEntityInputModule, never>;
|
|
50
|
-
static ɵmod: i0.ɵɵNgModuleDeclaration<NgxMatEntityInputModule, [typeof i1.StringInputComponent, typeof i2.StringTextboxInputComponent, typeof i3.StringAutocompleteInputComponent, typeof i4.StringDropdownInputComponent, typeof i5.StringPasswordInputComponent, typeof i6.BooleanCheckboxInputComponent, typeof i7.BooleanToggleInputComponent, typeof i8.BooleanDropdownInputComponent, typeof i9.NumberInputComponent, typeof i10.NumberDropdownInputComponent, typeof i11.NumberSliderInputComponent, typeof i12.ArrayStringChipsInputComponent, typeof i13.ArrayStringAutocompleteChipsComponent, typeof i14.DateInputComponent, typeof i15.DateRangeInputComponent, typeof i16.DateTimeInputComponent, typeof i17.ArrayDateInputComponent, typeof i18.ArrayDateTimeInputComponent, typeof i19.ArrayDateRangeInputComponent, typeof i20.FileInputComponent, typeof i21.FileImageInputComponent, typeof i22.FileDefaultInputComponent, typeof i23.DragDropDirective, typeof i24.ReferencesManyInputComponent, typeof i25.CustomInputComponent, typeof i26.NgxMatEntityInputComponent], [typeof i27.CommonModule, typeof i28.MatInputModule, typeof i29.FormsModule, typeof i30.MatFormFieldModule, typeof i31.MatSelectModule, typeof i32.MatAutocompleteModule, typeof i33.MatCheckboxModule, typeof i34.MatSlideToggleModule, typeof i35.MatChipsModule, typeof i36.MatIconModule, typeof i37.MatTableModule, typeof i38.MatDialogModule, typeof i39.MatButtonModule, typeof i40.MatDatepickerModule, typeof i41.MatSliderModule, typeof i42.MatTabsModule, typeof i43.MatMenuModule, typeof i44.MatProgressSpinnerModule, typeof i45.MatPaginatorModule, typeof i46.DisplayColumnValueComponent], [typeof i26.NgxMatEntityInputComponent]>;
|
|
51
|
+
static ɵmod: i0.ɵɵNgModuleDeclaration<NgxMatEntityInputModule, [typeof i1.StringInputComponent, typeof i2.StringTextboxInputComponent, typeof i3.StringAutocompleteInputComponent, typeof i4.StringDropdownInputComponent, typeof i5.StringPasswordInputComponent, typeof i6.BooleanCheckboxInputComponent, typeof i7.BooleanToggleInputComponent, typeof i8.BooleanDropdownInputComponent, typeof i9.NumberInputComponent, typeof i10.NumberDropdownInputComponent, typeof i11.NumberSliderInputComponent, typeof i12.ArrayStringChipsInputComponent, typeof i13.ArrayStringAutocompleteChipsComponent, typeof i14.DateInputComponent, typeof i15.DateRangeInputComponent, typeof i16.DateTimeInputComponent, typeof i17.ArrayDateInputComponent, typeof i18.ArrayDateTimeInputComponent, typeof i19.ArrayDateRangeInputComponent, typeof i20.FileInputComponent, typeof i21.FileImageInputComponent, typeof i22.FileDefaultInputComponent, typeof i23.DragDropDirective, typeof i24.ReferencesManyInputComponent, typeof i25.CustomInputComponent, typeof i26.NgxMatEntityInputComponent], [typeof i27.CommonModule, typeof i28.MatInputModule, typeof i29.FormsModule, typeof i30.MatFormFieldModule, typeof i31.MatSelectModule, typeof i32.MatAutocompleteModule, typeof i33.MatCheckboxModule, typeof i34.MatSlideToggleModule, typeof i35.MatChipsModule, typeof i36.MatIconModule, typeof i37.MatTableModule, typeof i38.MatDialogModule, typeof i39.MatButtonModule, typeof i40.MatDatepickerModule, typeof i41.MatSliderModule, typeof i42.MatTabsModule, typeof i43.MatMenuModule, typeof i44.MatProgressSpinnerModule, typeof i45.MatPaginatorModule, typeof i46.DisplayColumnValueComponent, typeof i47.MatSortModule], [typeof i26.NgxMatEntityInputComponent]>;
|
|
51
52
|
static ɵinj: i0.ɵɵInjectorDeclaration<NgxMatEntityInputModule>;
|
|
52
53
|
}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
/* eslint-disable jsdoc/require-jsdoc */
|
|
2
2
|
import { Component } from '@angular/core';
|
|
3
|
-
import { UUIDUtilities } from '
|
|
3
|
+
import { UUIDUtilities } from '../../../../encapsulation/uuid.utilities';
|
|
4
4
|
import { NgxMatEntityBaseInputComponent } from '../../base-input.component';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
import * as i1 from "@angular/common";
|
|
@@ -66,4 +66,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.0", ngImpor
|
|
|
66
66
|
type: Component,
|
|
67
67
|
args: [{ selector: 'array-string-chips-input', template: "<mat-form-field>\n <mat-label>{{metadata.displayName}}</mat-label>\n <mat-chip-grid #chipGrid\n [(ngModel)]=\"propertyValue\" [name]=\"key.toString() + uuid\" #model=\"ngModel\"\n [required]=\"metadata.required(entity)\"\n [disabled]=\"isReadOnly\"\n >\n <mat-chip-row *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-row>\n <input matInput\n [matChipInputFor]=\"chipGrid\"\n [matChipInputAddOnBlur]=\"true\"\n (matChipInputTokenEnd)=\"addStringChipArrayValue($event)\"\n [(ngModel)]=\"chipsInput\" [name]=\"key.toString() + uuid2\" #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-grid>\n <mat-error *ngIf=\"!chipsModel.errors\">{{getValidationErrorMessage(model)}}</mat-error>\n</mat-form-field>", styles: ["mat-form-field{width:100%}\n"] }]
|
|
68
68
|
}] });
|
|
69
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
69
|
+
//# 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;AAIlD,OAAO,EAAE,aAAa,EAAE,MAAM,0CAA0C,CAAC;AACzE,OAAO,EAAE,8BAA8B,EAAE,MAAM,4BAA4B,CAAC;;;;;;;AAQ5E,MAAM,OAAO,8BACT,SAAQ,8BAAuF;IAE/F,KAAK,GAAW,aAAa,CAAC,MAAM,EAAE,CAAC;IACvC,UAAU,GAAW,EAAE,CAAC;IAExB;;;;;;;;;;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;QACzB,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;QAErB,IAAI,CAAC,UAAU,EAAE,CAAC;IACtB,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;QAEjF,IAAI,CAAC,UAAU,EAAE,CAAC;IACtB,CAAC;IAES,2BAA2B,CAAC,KAAa;QAC/C,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;uGAzDQ,8BAA8B;2FAA9B,8BAA8B,uFCd3C,mwCAyBiB;;2FDXJ,8BAA8B;kBAN1C,SAAS;+BAEI,0BAA0B","sourcesContent":["/* eslint-disable jsdoc/require-jsdoc */\nimport { Component, OnInit } from '@angular/core';\nimport { MatChipInputEvent } from '@angular/material/chips';\nimport { BaseEntityType } from '../../../../classes/entity.model';\nimport { DecoratorTypes } from '../../../../decorators/base/decorator-types.enum';\nimport { UUIDUtilities } from '../../../../encapsulation/uuid.utilities';\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    uuid2: string = UUIDUtilities.create();\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        this.chipsInput = '';\n\n        this.emitChange();\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        this.emitChange();\n    }\n\n    protected 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-grid #chipGrid\n        [(ngModel)]=\"propertyValue\" [name]=\"key.toString() + uuid\" #model=\"ngModel\"\n        [required]=\"metadata.required(entity)\"\n        [disabled]=\"isReadOnly\"\n    >\n        <mat-chip-row *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-row>\n        <input matInput\n            [matChipInputFor]=\"chipGrid\"\n            [matChipInputAddOnBlur]=\"true\"\n            (matChipInputTokenEnd)=\"addStringChipArrayValue($event)\"\n            [(ngModel)]=\"chipsInput\" [name]=\"key.toString() + uuid2\" #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-grid>\n    <mat-error *ngIf=\"!chipsModel.errors\">{{getValidationErrorMessage(model)}}</mat-error>\n</mat-form-field>"]}
|