ngx-material-entity 0.1.1 → 0.1.4
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/CONTRIBUTING.md +7 -1
- package/README.md +536 -328
- package/classes/base.builder.d.ts +35 -0
- package/classes/date.utilities.d.ts +58 -0
- package/classes/entity.model.d.ts +13 -0
- package/classes/{entity-service.class.d.ts → entity.service.d.ts} +35 -20
- package/classes/entity.utilities.d.ts +153 -0
- package/components/confirm-dialog/confirm-dialog-data.builder.d.ts +23 -0
- package/components/confirm-dialog/confirm-dialog-data.d.ts +18 -8
- package/components/confirm-dialog/confirm-dialog.component.d.ts +15 -5
- package/components/get-validation-error-message.function.d.ts +3 -2
- package/components/input/add-array-item-dialog-data.builder.d.ts +20 -0
- package/components/input/add-array-item-dialog-data.d.ts +19 -0
- package/components/input/input.component.d.ts +151 -30
- package/components/input/input.module.d.ts +7 -4
- package/components/table/create-dialog/create-dialog-data.builder.d.ts +21 -0
- package/components/table/create-dialog/create-entity-dialog-data.builder.d.ts +21 -0
- package/components/table/create-dialog/create-entity-dialog-data.d.ts +4 -5
- package/components/table/create-dialog/create-entity-dialog.component.d.ts +21 -8
- package/components/table/edit-dialog/edit-dialog-data.builder.d.ts +24 -0
- package/components/table/edit-dialog/edit-entity-dialog-data.d.ts +7 -8
- package/components/table/edit-dialog/edit-entity-dialog.builder.d.ts +22 -0
- package/components/table/edit-dialog/edit-entity-dialog.component.d.ts +25 -8
- package/components/table/table-data.builder.d.ts +51 -0
- package/components/table/table-data.d.ts +46 -30
- package/components/table/table.component.d.ts +53 -7
- package/components/table/table.module.d.ts +3 -1
- package/decorators/array/array-decorator-internal.data.d.ts +45 -0
- package/decorators/array/array-decorator.data.d.ts +129 -0
- package/decorators/array/array.decorator.d.ts +9 -0
- package/decorators/base/base-property.decorator.d.ts +7 -6
- package/decorators/base/decorator-types.enum.d.ts +12 -9
- package/decorators/base/dropdown-value.interface.d.ts +14 -0
- package/decorators/base/property-decorator-internal.data.d.ts +24 -0
- package/decorators/base/property-decorator.data.d.ts +70 -0
- package/decorators/boolean/boolean-decorator-internal.data.d.ts +25 -0
- package/decorators/boolean/boolean-decorator.data.d.ts +37 -0
- package/decorators/boolean/boolean.decorator.d.ts +8 -0
- package/decorators/date/date-decorator-internal.data.d.ts +44 -0
- package/decorators/date/date-decorator.data.d.ts +129 -0
- package/decorators/number/number-decorator-internal.data.d.ts +20 -0
- package/decorators/number/number-decorator.data.d.ts +36 -0
- package/decorators/number/number.decorator.d.ts +8 -0
- package/decorators/object/object-decorator-internal.data.d.ts +11 -0
- package/decorators/object/object-decorator.data.d.ts +25 -0
- package/decorators/object/object.decorator.d.ts +8 -0
- package/decorators/string/string-decorator-internal.data.d.ts +41 -0
- package/decorators/string/string-decorator.data.d.ts +77 -0
- package/decorators/string/string.decorator.d.ts +8 -0
- package/esm2020/classes/base.builder.mjs +43 -0
- package/esm2020/classes/date.utilities.mjs +138 -0
- package/esm2020/classes/entity.model.mjs +19 -0
- package/esm2020/classes/entity.service.mjs +83 -0
- package/esm2020/classes/entity.utilities.mjs +538 -0
- package/esm2020/components/confirm-dialog/confirm-dialog-data.builder.mjs +44 -0
- package/esm2020/components/confirm-dialog/confirm-dialog-data.mjs +1 -1
- package/esm2020/components/confirm-dialog/confirm-dialog.component.mjs +18 -22
- package/esm2020/components/get-validation-error-message.function.mjs +8 -3
- package/esm2020/components/input/add-array-item-dialog-data.builder.mjs +30 -0
- package/esm2020/components/input/add-array-item-dialog-data.mjs +2 -0
- package/esm2020/components/input/input.component.mjs +240 -36
- package/esm2020/components/input/input.module.mjs +23 -9
- package/esm2020/components/table/create-dialog/create-dialog-data.builder.mjs +32 -0
- package/esm2020/components/table/create-dialog/create-entity-dialog-data.builder.mjs +26 -0
- package/esm2020/components/table/create-dialog/create-entity-dialog-data.mjs +1 -1
- package/esm2020/components/table/create-dialog/create-entity-dialog.component.mjs +31 -31
- package/esm2020/components/table/create-dialog/create-entity-dialog.module.mjs +20 -4
- package/esm2020/components/table/edit-dialog/edit-dialog-data.builder.mjs +41 -0
- package/esm2020/components/table/edit-dialog/edit-entity-dialog-data.mjs +1 -1
- package/esm2020/components/table/edit-dialog/edit-entity-dialog.builder.mjs +27 -0
- package/esm2020/components/table/edit-dialog/edit-entity-dialog.component.mjs +45 -49
- package/esm2020/components/table/table-data.builder.mjs +105 -0
- package/esm2020/components/table/table-data.mjs +1 -1
- package/esm2020/components/table/table.component.mjs +91 -83
- package/esm2020/components/table/table.module.mjs +12 -4
- package/esm2020/decorators/array/array-decorator-internal.data.mjs +51 -0
- package/esm2020/decorators/array/array-decorator.data.mjs +7 -0
- package/esm2020/decorators/array/array.decorator.mjs +24 -0
- package/esm2020/decorators/base/base-property.decorator.mjs +6 -5
- package/esm2020/decorators/base/decorator-types.enum.mjs +4 -1
- package/esm2020/decorators/base/dropdown-value.interface.mjs +2 -0
- package/esm2020/decorators/base/property-decorator-internal.data.mjs +38 -0
- package/esm2020/decorators/base/property-decorator.data.mjs +6 -0
- package/esm2020/decorators/boolean/boolean-decorator-internal.data.mjs +33 -0
- package/esm2020/decorators/boolean/boolean-decorator.data.mjs +7 -0
- package/esm2020/decorators/boolean/boolean.decorator.mjs +21 -0
- package/esm2020/decorators/date/date-decorator-internal.data.mjs +48 -0
- package/esm2020/decorators/date/date-decorator.data.mjs +7 -0
- package/esm2020/decorators/number/number-decorator-internal.data.mjs +23 -0
- package/esm2020/decorators/number/number-decorator.data.mjs +7 -0
- package/esm2020/decorators/number/number.decorator.mjs +18 -0
- package/esm2020/decorators/object/object-decorator-internal.data.mjs +12 -0
- package/esm2020/decorators/object/object-decorator.data.mjs +7 -0
- package/esm2020/decorators/object/object.decorator.mjs +13 -0
- package/esm2020/decorators/string/string-decorator-internal.data.mjs +48 -0
- package/esm2020/decorators/string/string-decorator.data.mjs +7 -0
- package/esm2020/decorators/string/string.decorator.mjs +24 -0
- package/esm2020/public-api.mjs +20 -13
- package/fesm2015/ngx-material-entity.mjs +1664 -944
- package/fesm2015/ngx-material-entity.mjs.map +1 -1
- package/fesm2020/ngx-material-entity.mjs +1667 -941
- package/fesm2020/ngx-material-entity.mjs.map +1 -1
- package/package.json +7 -1
- package/public-api.d.ts +21 -10
- package/classes/entity-model.class.d.ts +0 -9
- package/classes/entity-utilities.class.d.ts +0 -95
- package/components/input/array-table/add-array-item-dialog/add-array-item-dialog.component.d.ts +0 -35
- package/components/input/array-table/add-array-item-dialog/add-array-item-dialog.module.d.ts +0 -12
- package/components/input/array-table/array-table.component.d.ts +0 -34
- package/components/input/array-table/array-table.module.d.ts +0 -19
- package/components/input/internal-input/internal-input.component.d.ts +0 -57
- package/components/input/internal-input/internal-input.module.d.ts +0 -16
- package/decorators/array.decorator.d.ts +0 -125
- package/decorators/base/property-decorator-config.interface.d.ts +0 -50
- package/decorators/boolean.decorator.d.ts +0 -42
- package/decorators/number.decorator.d.ts +0 -40
- package/decorators/object.decorator.d.ts +0 -27
- package/decorators/string.decorator.d.ts +0 -76
- package/esm2020/classes/entity-model.class.mjs +0 -19
- package/esm2020/classes/entity-service.class.mjs +0 -70
- package/esm2020/classes/entity-utilities.class.mjs +0 -296
- package/esm2020/components/input/array-table/add-array-item-dialog/add-array-item-dialog.component.mjs +0 -43
- package/esm2020/components/input/array-table/add-array-item-dialog/add-array-item-dialog.module.mjs +0 -22
- package/esm2020/components/input/array-table/array-table.component.mjs +0 -116
- package/esm2020/components/input/array-table/array-table.module.mjs +0 -66
- package/esm2020/components/input/internal-input/internal-input.component.mjs +0 -73
- package/esm2020/components/input/internal-input/internal-input.module.mjs +0 -54
- package/esm2020/decorators/array.decorator.mjs +0 -70
- package/esm2020/decorators/base/property-decorator-config.interface.mjs +0 -31
- package/esm2020/decorators/boolean.decorator.mjs +0 -44
- package/esm2020/decorators/number.decorator.mjs +0 -36
- package/esm2020/decorators/object.decorator.mjs +0 -23
- package/esm2020/decorators/string.decorator.mjs +0 -61
|
@@ -8,6 +8,10 @@ import { MatDialog } from '@angular/material/dialog';
|
|
|
8
8
|
import { NgxMatEntityCreateDialogComponent } from './create-dialog/create-entity-dialog.component';
|
|
9
9
|
import { NgxMatEntityEditDialogComponent } from './edit-dialog/edit-entity-dialog.component';
|
|
10
10
|
import { NgxMatEntityConfirmDialogComponent } from '../confirm-dialog/confirm-dialog.component';
|
|
11
|
+
import { ConfirmDialogDataBuilder } from '../confirm-dialog/confirm-dialog-data.builder';
|
|
12
|
+
import { CreateEntityDialogDataBuilder } from './create-dialog/create-entity-dialog-data.builder';
|
|
13
|
+
import { TableDataBuilder } from './table-data.builder';
|
|
14
|
+
import { EditEntityDialogDataBuilder } from '../table/edit-dialog/edit-entity-dialog.builder';
|
|
11
15
|
import * as i0 from "@angular/core";
|
|
12
16
|
import * as i1 from "@angular/material/dialog";
|
|
13
17
|
import * as i2 from "@angular/material/form-field";
|
|
@@ -18,6 +22,12 @@ import * as i6 from "@angular/material/checkbox";
|
|
|
18
22
|
import * as i7 from "@angular/material/paginator";
|
|
19
23
|
import * as i8 from "@angular/material/input";
|
|
20
24
|
import * as i9 from "@angular/common";
|
|
25
|
+
/**
|
|
26
|
+
* Generates a fully functional table for displaying, creating, updating and deleting entities
|
|
27
|
+
* based on the configuration passed in the @Input "tableData".
|
|
28
|
+
*
|
|
29
|
+
* It offers a lot of customization options which can be found in "TableData".
|
|
30
|
+
*/
|
|
21
31
|
export class NgxMatEntityTableComponent {
|
|
22
32
|
constructor(dialog, injector) {
|
|
23
33
|
this.dialog = dialog;
|
|
@@ -26,27 +36,26 @@ export class NgxMatEntityTableComponent {
|
|
|
26
36
|
this.dataSource = new MatTableDataSource();
|
|
27
37
|
this.selection = new SelectionModel(true, []);
|
|
28
38
|
}
|
|
39
|
+
/**
|
|
40
|
+
* Sets up all the configuration for the table and the EntityService.
|
|
41
|
+
*/
|
|
29
42
|
ngOnInit() {
|
|
30
|
-
this.
|
|
31
|
-
this.entityService = this.injector.get(this.
|
|
32
|
-
const givenDisplayColumns = this.
|
|
33
|
-
if (this.
|
|
34
|
-
if (givenDisplayColumns.find((s) => s === 'select')) {
|
|
35
|
-
throw new Error(`The name "select" for a display column is reserved for the multi-select action functionality.
|
|
36
|
-
Please choose a different name.`);
|
|
37
|
-
}
|
|
43
|
+
this.data = new TableDataBuilder(this.tableData).getResult();
|
|
44
|
+
this.entityService = this.injector.get(this.data.baseData.EntityServiceClass);
|
|
45
|
+
const givenDisplayColumns = this.data.baseData.displayColumns.map((v) => v.displayName);
|
|
46
|
+
if (this.data.baseData.multiSelectActions.length) {
|
|
38
47
|
this.displayedColumns = ['select'].concat(givenDisplayColumns);
|
|
39
48
|
}
|
|
40
49
|
else {
|
|
41
50
|
this.displayedColumns = givenDisplayColumns;
|
|
42
51
|
}
|
|
43
52
|
this.dataSource.sortingDataAccessor = (entity, header) => {
|
|
44
|
-
return this.
|
|
53
|
+
return this.data.baseData.displayColumns.find((dp) => dp.displayName === header)?.value(entity);
|
|
45
54
|
};
|
|
46
55
|
this.dataSource.sort = this.sort;
|
|
47
|
-
if (this.
|
|
56
|
+
if (this.data.baseData.searchString) {
|
|
48
57
|
this.dataSource.filterPredicate = (entity, filter) => {
|
|
49
|
-
const searchStr = this.
|
|
58
|
+
const searchStr = this.data.baseData.searchString(entity);
|
|
50
59
|
const formattedSearchString = searchStr.toLowerCase();
|
|
51
60
|
const formattedFilterString = filter.toLowerCase();
|
|
52
61
|
return formattedSearchString.includes(formattedFilterString);
|
|
@@ -60,62 +69,33 @@ export class NgxMatEntityTableComponent {
|
|
|
60
69
|
});
|
|
61
70
|
this.entityService.read();
|
|
62
71
|
}
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
}
|
|
70
|
-
if (!this.entitiesData.baseData.EntityServiceClass) {
|
|
71
|
-
throw new Error('Missing required Input data "EntityServiceClass"');
|
|
72
|
-
}
|
|
73
|
-
if (this.entitiesData.baseData.allowCreate === undefined) {
|
|
74
|
-
this.entitiesData.baseData.allowCreate = true;
|
|
75
|
-
}
|
|
76
|
-
if (this.entitiesData.baseData.allowEdit === undefined) {
|
|
77
|
-
this.entitiesData.baseData.allowEdit = () => true;
|
|
78
|
-
}
|
|
79
|
-
if (this.entitiesData.baseData.allowDelete === undefined) {
|
|
80
|
-
this.entitiesData.baseData.allowDelete = () => true;
|
|
81
|
-
}
|
|
82
|
-
if ((this.entitiesData.baseData.allowEdit !== (() => false)
|
|
83
|
-
|| this.entitiesData.baseData.allowDelete !== (() => false)
|
|
84
|
-
|| this.entitiesData.baseData.allowCreate)
|
|
85
|
-
&& !this.entitiesData.baseData.EntityClass) {
|
|
86
|
-
throw new Error(`
|
|
87
|
-
Missing required Input data "EntityClass".
|
|
88
|
-
You can only omit this value if you can neither create or update entities.`);
|
|
89
|
-
}
|
|
90
|
-
if (this.entitiesData.baseData.allowCreate && !this.entitiesData.baseData.create && !this.entitiesData.createDialogData) {
|
|
91
|
-
throw new Error(`Missing required Input data "createDialogData".
|
|
92
|
-
You can only omit this value when creation is disallowed or done with a custom create method.`);
|
|
93
|
-
}
|
|
94
|
-
if ((this.entitiesData.baseData.allowEdit !== (() => false)
|
|
95
|
-
|| this.entitiesData.baseData.allowDelete !== (() => false))
|
|
96
|
-
&& !this.entitiesData.baseData.edit
|
|
97
|
-
&& !this.entitiesData.editDialogData) {
|
|
98
|
-
throw new Error(`Missing required Input data "editDialogData".
|
|
99
|
-
You can only omit this value when editing and deleting is disallowed or done with a custom edit method.`);
|
|
100
|
-
}
|
|
101
|
-
}
|
|
72
|
+
/**
|
|
73
|
+
* Edits an entity. This either calls the edit-Method provided by the user or uses a default edit-dialog.
|
|
74
|
+
*
|
|
75
|
+
* @param entity - The entity that should be updated.
|
|
76
|
+
* @throws When no EntityClass was provided, as a new call is needed to initialize metadata.
|
|
77
|
+
*/
|
|
102
78
|
editEntity(entity) {
|
|
103
|
-
if (this.
|
|
104
|
-
if (this.
|
|
105
|
-
|
|
79
|
+
if (this.data.baseData.allowEdit(entity)) {
|
|
80
|
+
if (!this.data.baseData.EntityClass) {
|
|
81
|
+
throw new Error('No "EntityClass" specified for this table');
|
|
82
|
+
}
|
|
83
|
+
if (this.data.baseData.edit) {
|
|
84
|
+
this.data.baseData.edit(new this.data.baseData.EntityClass(entity));
|
|
106
85
|
}
|
|
107
86
|
else {
|
|
108
|
-
this.editDefault(new this.
|
|
87
|
+
this.editDefault(new this.data.baseData.EntityClass(entity));
|
|
109
88
|
}
|
|
110
89
|
}
|
|
111
90
|
}
|
|
112
91
|
editDefault(entity) {
|
|
113
|
-
const
|
|
92
|
+
const inputDialogData = {
|
|
114
93
|
entity: entity,
|
|
115
|
-
EntityServiceClass: this.
|
|
116
|
-
allowDelete: this.
|
|
117
|
-
editDialogData: this.
|
|
94
|
+
EntityServiceClass: this.data.baseData.EntityServiceClass,
|
|
95
|
+
allowDelete: this.data.baseData.allowDelete,
|
|
96
|
+
editDialogData: this.data.editDialogData
|
|
118
97
|
};
|
|
98
|
+
const dialogData = new EditEntityDialogDataBuilder(inputDialogData).getResult();
|
|
119
99
|
firstValueFrom(this.dialog.open(NgxMatEntityEditDialogComponent, {
|
|
120
100
|
data: dialogData,
|
|
121
101
|
minWidth: '60%',
|
|
@@ -124,28 +104,36 @@ export class NgxMatEntityTableComponent {
|
|
|
124
104
|
}).afterClosed()).then((res) => {
|
|
125
105
|
if (res === 0) {
|
|
126
106
|
const data = this.dataSource.data;
|
|
127
|
-
data[this.dataSource.data.findIndex((e) => e.
|
|
107
|
+
data[this.dataSource.data.findIndex((e) => e[this.entityService.idKey] === entity[this.entityService.idKey])] = entity;
|
|
128
108
|
this.dataSource.data = data;
|
|
129
109
|
this.selection.clear();
|
|
130
110
|
}
|
|
131
111
|
});
|
|
132
112
|
}
|
|
113
|
+
/**
|
|
114
|
+
* Creates a new Entity. This either calls the create-Method provided by the user or uses a default create-dialog.
|
|
115
|
+
*
|
|
116
|
+
* @throws When no EntityClass was provided, as a new call is needed to initialize metadata.
|
|
117
|
+
*/
|
|
133
118
|
createEntity() {
|
|
134
|
-
if (this.
|
|
135
|
-
if (this.
|
|
136
|
-
|
|
119
|
+
if (this.data.baseData.allowCreate) {
|
|
120
|
+
if (!this.data.baseData.EntityClass) {
|
|
121
|
+
throw new Error('No "EntityClass" specified for this table');
|
|
122
|
+
}
|
|
123
|
+
if (this.data.baseData.create) {
|
|
124
|
+
this.data.baseData.create(new this.data.baseData.EntityClass());
|
|
137
125
|
}
|
|
138
126
|
else {
|
|
139
|
-
this.createDefault(new this.
|
|
127
|
+
this.createDefault(new this.data.baseData.EntityClass());
|
|
140
128
|
}
|
|
141
129
|
}
|
|
142
130
|
}
|
|
143
131
|
createDefault(entity) {
|
|
144
|
-
const dialogData = {
|
|
132
|
+
const dialogData = new CreateEntityDialogDataBuilder({
|
|
145
133
|
entity: entity,
|
|
146
|
-
EntityServiceClass: this.
|
|
147
|
-
createDialogData: this.
|
|
148
|
-
};
|
|
134
|
+
EntityServiceClass: this.data.baseData.EntityServiceClass,
|
|
135
|
+
createDialogData: this.data.createDialogData
|
|
136
|
+
}).getResult();
|
|
149
137
|
this.dialog.open(NgxMatEntityCreateDialogComponent, {
|
|
150
138
|
data: dialogData,
|
|
151
139
|
minWidth: '60%',
|
|
@@ -153,26 +141,26 @@ export class NgxMatEntityTableComponent {
|
|
|
153
141
|
restoreFocus: false
|
|
154
142
|
});
|
|
155
143
|
}
|
|
144
|
+
/**
|
|
145
|
+
* Runs the MultiAction for all selected entries.
|
|
146
|
+
* Also handles confirmation with an additional dialog if configured.
|
|
147
|
+
*
|
|
148
|
+
* @param action - The MultiAction to run.
|
|
149
|
+
*/
|
|
156
150
|
runMultiAction(action) {
|
|
157
151
|
if (!action.requireConfirmDialog || !action.requireConfirmDialog(this.selection.selected)) {
|
|
158
152
|
return this.confirmRunMultiAction(action);
|
|
159
153
|
}
|
|
160
|
-
const dialogData =
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
cancelButtonLabel: action.confirmDialogData?.cancelButtonLabel ? action.confirmDialogData?.cancelButtonLabel : 'Cancel',
|
|
166
|
-
title: action.confirmDialogData?.title ? action.confirmDialogData?.title : action.displayName,
|
|
167
|
-
requireConfirmation: action.confirmDialogData?.requireConfirmation ? action.confirmDialogData?.requireConfirmation : false,
|
|
168
|
-
confirmationText: action.confirmDialogData?.confirmationText ? action.confirmDialogData?.confirmationText : undefined
|
|
169
|
-
};
|
|
170
|
-
const dialogref = this.dialog.open(NgxMatEntityConfirmDialogComponent, {
|
|
154
|
+
const dialogData = new ConfirmDialogDataBuilder(action.confirmDialogData)
|
|
155
|
+
.withDefault('text', [`Do you really want to run this action on ${this.selection.selected.length} entries?`])
|
|
156
|
+
.withDefault('title', action.displayName)
|
|
157
|
+
.getResult();
|
|
158
|
+
const dialogRef = this.dialog.open(NgxMatEntityConfirmDialogComponent, {
|
|
171
159
|
data: dialogData,
|
|
172
160
|
autoFocus: false,
|
|
173
161
|
restoreFocus: false
|
|
174
162
|
});
|
|
175
|
-
|
|
163
|
+
dialogRef.afterClosed().subscribe((res) => {
|
|
176
164
|
if (res === 1) {
|
|
177
165
|
this.confirmRunMultiAction(action);
|
|
178
166
|
}
|
|
@@ -181,6 +169,12 @@ export class NgxMatEntityTableComponent {
|
|
|
181
169
|
confirmRunMultiAction(action) {
|
|
182
170
|
action.action(this.selection.selected);
|
|
183
171
|
}
|
|
172
|
+
/**
|
|
173
|
+
* Checks if an MultiAction is disabled (e.g. Because no entries have been selected).
|
|
174
|
+
*
|
|
175
|
+
* @param action - The MultiAction to check.
|
|
176
|
+
* @returns Whether or not the Action can be used.
|
|
177
|
+
*/
|
|
184
178
|
multiActionDisabled(action) {
|
|
185
179
|
if (!this.selection.selected.length) {
|
|
186
180
|
return true;
|
|
@@ -190,6 +184,9 @@ export class NgxMatEntityTableComponent {
|
|
|
190
184
|
}
|
|
191
185
|
return false;
|
|
192
186
|
}
|
|
187
|
+
/**
|
|
188
|
+
* Toggles all entries in the table.
|
|
189
|
+
*/
|
|
193
190
|
masterToggle() {
|
|
194
191
|
if (this.isAllSelected()) {
|
|
195
192
|
this.selection.clear();
|
|
@@ -198,6 +195,12 @@ export class NgxMatEntityTableComponent {
|
|
|
198
195
|
this.dataSource.data.forEach((row) => this.selection.select(row));
|
|
199
196
|
}
|
|
200
197
|
}
|
|
198
|
+
/**
|
|
199
|
+
* Checks if all entries in the table have been selected.
|
|
200
|
+
* This is needed to display the "masterToggle"-checkbox correctly.
|
|
201
|
+
*
|
|
202
|
+
* @returns Whether or not all entries in the table have been selected.
|
|
203
|
+
*/
|
|
201
204
|
isAllSelected() {
|
|
202
205
|
const numSelected = this.selection.selected.length;
|
|
203
206
|
const numRows = this.dataSource.data.length;
|
|
@@ -207,17 +210,22 @@ export class NgxMatEntityTableComponent {
|
|
|
207
210
|
this.onDestroy.next(undefined);
|
|
208
211
|
this.onDestroy.complete();
|
|
209
212
|
}
|
|
213
|
+
/**
|
|
214
|
+
* Applies the search input to filter the table entries.
|
|
215
|
+
*
|
|
216
|
+
* @param event - The keyup-event which contains the search-string of the user.
|
|
217
|
+
*/
|
|
210
218
|
applyFilter(event) {
|
|
211
219
|
const filterValue = event.target.value;
|
|
212
220
|
this.dataSource.filter = filterValue.trim().toLowerCase();
|
|
213
221
|
}
|
|
214
222
|
}
|
|
215
223
|
NgxMatEntityTableComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: NgxMatEntityTableComponent, deps: [{ token: i1.MatDialog }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Component });
|
|
216
|
-
NgxMatEntityTableComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: NgxMatEntityTableComponent, selector: "ngx-mat-entity-table", inputs: {
|
|
224
|
+
NgxMatEntityTableComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: NgxMatEntityTableComponent, selector: "ngx-mat-entity-table", inputs: { tableData: "tableData" }, viewQueries: [{ propertyName: "paginator", first: true, predicate: MatPaginator, descendants: true, static: true }, { propertyName: "sort", first: true, predicate: MatSort, descendants: true, static: true }, { propertyName: "filter", first: true, predicate: ["filter"], descendants: true, static: true }], ngImport: i0, template: "<h1 class=\"title\">{{data.baseData.title}}</h1>\n\n<div class=\"row\">\n <mat-form-field class=\"col-lg-8 col-md-6 col-sm-12\">\n <mat-label>{{data.baseData.searchLabel}}</mat-label>\n <input matInput (keyup)=\"applyFilter($event)\" />\n </mat-form-field>\n <div\n *ngIf=\"data.baseData.multiSelectActions.length\"\n [class.col-lg-2]=\"data.baseData.allowCreate\"\n [class.col-lg-4]=\"!data.baseData.allowCreate\"\n [class.col-md-3]=\"data.baseData.allowCreate\"\n [class.col-md-6]=\"!data.baseData.allowCreate\"\n [class.col-sm-6]=\"data.baseData.allowCreate\"\n [class.col-sm-12]=\"!data.baseData.allowCreate\"\n >\n <button class=\"actions-button\" [matMenuTriggerFor]=\"menu\" mat-raised-button>\n {{data.baseData.multiSelectLabel}}\n </button>\n </div>\n <mat-menu #menu=\"matMenu\">\n <button *ngFor=\"let action of data.baseData.multiSelectActions\" [disabled]=\"multiActionDisabled(action)\" (click)=\"runMultiAction(action)\" mat-menu-item>\n {{action.displayName}}\n </button>\n </mat-menu>\n\n <div\n *ngIf=\"data.baseData.allowCreate\"\n [class.col-lg-2]=\"data.baseData.multiSelectActions.length\"\n [class.col-lg-4]=\"!data.baseData.multiSelectActions.length\"\n [class.col-md-3]=\"data.baseData.multiSelectActions.length\"\n [class.col-md-6]=\"!data.baseData.multiSelectActions.length\"\n [class.col-sm-6]=\"data.baseData.multiSelectActions.length\"\n [class.col-sm-12]=\"!data.baseData.multiSelectActions.length\"\n >\n <button class=\"create-button\" (click)=\"createEntity()\" mat-raised-button>\n {{data.baseData.createButtonLabel}}\n </button>\n </div>\n</div>\n\n<div class=\"mat-elevation-z8\">\n <mat-table *ngIf=\"dataSource\" [dataSource]=\"dataSource\" matSort>\n <!-- select Column -->\n <ng-container matColumnDef=\"select\">\n <mat-header-cell *matHeaderCellDef>\n <mat-checkbox (change)=\"$event ? masterToggle() : null\" [checked]=\"selection.hasValue() && isAllSelected()\" [indeterminate]=\"selection.hasValue() && !isAllSelected()\"> </mat-checkbox>\n </mat-header-cell>\n <mat-cell *matCellDef=\"let module\" class=\"module\">\n <mat-checkbox (click)=\"$event.stopPropagation()\" (change)=\"$event ? selection.toggle(module) : null\" [checked]=\"selection.isSelected(module)\"> </mat-checkbox>\n </mat-cell>\n </ng-container>\n\n <ng-container *ngFor=\"let dCol of data.baseData.displayColumns\" [matColumnDef]=\"dCol.displayName\">\n <mat-header-cell *matHeaderCellDef mat-sort-header>\n {{dCol.displayName}}\n </mat-header-cell>\n <mat-cell class=\"entity\" [class.enabled]=\"data.baseData.allowEdit(entity)\" (click)=\"editEntity(entity)\" *matCellDef=\"let entity\">\n {{dCol.value(entity)}}\n </mat-cell>\n </ng-container>\n\n <mat-header-row *matHeaderRowDef=\"displayedColumns\"></mat-header-row>\n <mat-row *matRowDef=\"let row; columns: displayedColumns\"></mat-row>\n </mat-table>\n\n <mat-paginator *ngIf=\"dataSource\" id=\"paginator\" [length]=\"dataSource.filteredData.length\" [pageIndex]=\"0\" [pageSize]=\"10\" [pageSizeOptions]=\"[5, 10, 25, 50]\"> </mat-paginator>\n</div>\n", styles: [".title{text-align:center}button{width:100%}.mat-column-select{flex:0 0 75px}.enabled:hover{cursor:pointer}@media (max-width: 767px){.actions-button,.create-button{margin-bottom:15px}}\n"], components: [{ type: i2.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { type: i3.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { type: i4.MatMenu, selector: "mat-menu", exportAs: ["matMenu"] }, { type: i4.MatMenuItem, selector: "[mat-menu-item]", inputs: ["disabled", "disableRipple", "role"], exportAs: ["matMenuItem"] }, { type: i5.MatTable, selector: "mat-table, table[mat-table]", exportAs: ["matTable"] }, { type: i6.MatCheckbox, selector: "mat-checkbox", inputs: ["disableRipple", "color", "tabIndex", "aria-label", "aria-labelledby", "aria-describedby", "id", "required", "labelPosition", "name", "value", "checked", "disabled", "indeterminate"], outputs: ["change", "indeterminateChange"], exportAs: ["matCheckbox"] }, { type: i5.MatHeaderRow, selector: "mat-header-row, tr[mat-header-row]", exportAs: ["matHeaderRow"] }, { type: i5.MatRow, selector: "mat-row, tr[mat-row]", exportAs: ["matRow"] }, { type: i7.MatPaginator, selector: "mat-paginator", inputs: ["disabled"], exportAs: ["matPaginator"] }], directives: [{ type: i2.MatLabel, selector: "mat-label" }, { type: i8.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"] }, { type: i9.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i4.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", exportAs: ["matMenuTrigger"] }, { type: i9.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i5.MatColumnDef, selector: "[matColumnDef]", inputs: ["sticky", "matColumnDef"] }, { type: i5.MatHeaderCellDef, selector: "[matHeaderCellDef]" }, { type: i5.MatHeaderCell, selector: "mat-header-cell, th[mat-header-cell]" }, { type: i5.MatCellDef, selector: "[matCellDef]" }, { type: i5.MatCell, selector: "mat-cell, td[mat-cell]" }, { type: i5.MatHeaderRowDef, selector: "[matHeaderRowDef]", inputs: ["matHeaderRowDef", "matHeaderRowDefSticky"] }, { type: i5.MatRowDef, selector: "[matRowDef]", inputs: ["matRowDefColumns", "matRowDefWhen"] }] });
|
|
217
225
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: NgxMatEntityTableComponent, decorators: [{
|
|
218
226
|
type: Component,
|
|
219
|
-
args: [{ selector: 'ngx-mat-entity-table', template: "<h1 class=\"title\">{{
|
|
220
|
-
}], ctorParameters: function () { return [{ type: i1.MatDialog }, { type: i0.Injector }]; }, propDecorators: {
|
|
227
|
+
args: [{ selector: 'ngx-mat-entity-table', template: "<h1 class=\"title\">{{data.baseData.title}}</h1>\n\n<div class=\"row\">\n <mat-form-field class=\"col-lg-8 col-md-6 col-sm-12\">\n <mat-label>{{data.baseData.searchLabel}}</mat-label>\n <input matInput (keyup)=\"applyFilter($event)\" />\n </mat-form-field>\n <div\n *ngIf=\"data.baseData.multiSelectActions.length\"\n [class.col-lg-2]=\"data.baseData.allowCreate\"\n [class.col-lg-4]=\"!data.baseData.allowCreate\"\n [class.col-md-3]=\"data.baseData.allowCreate\"\n [class.col-md-6]=\"!data.baseData.allowCreate\"\n [class.col-sm-6]=\"data.baseData.allowCreate\"\n [class.col-sm-12]=\"!data.baseData.allowCreate\"\n >\n <button class=\"actions-button\" [matMenuTriggerFor]=\"menu\" mat-raised-button>\n {{data.baseData.multiSelectLabel}}\n </button>\n </div>\n <mat-menu #menu=\"matMenu\">\n <button *ngFor=\"let action of data.baseData.multiSelectActions\" [disabled]=\"multiActionDisabled(action)\" (click)=\"runMultiAction(action)\" mat-menu-item>\n {{action.displayName}}\n </button>\n </mat-menu>\n\n <div\n *ngIf=\"data.baseData.allowCreate\"\n [class.col-lg-2]=\"data.baseData.multiSelectActions.length\"\n [class.col-lg-4]=\"!data.baseData.multiSelectActions.length\"\n [class.col-md-3]=\"data.baseData.multiSelectActions.length\"\n [class.col-md-6]=\"!data.baseData.multiSelectActions.length\"\n [class.col-sm-6]=\"data.baseData.multiSelectActions.length\"\n [class.col-sm-12]=\"!data.baseData.multiSelectActions.length\"\n >\n <button class=\"create-button\" (click)=\"createEntity()\" mat-raised-button>\n {{data.baseData.createButtonLabel}}\n </button>\n </div>\n</div>\n\n<div class=\"mat-elevation-z8\">\n <mat-table *ngIf=\"dataSource\" [dataSource]=\"dataSource\" matSort>\n <!-- select Column -->\n <ng-container matColumnDef=\"select\">\n <mat-header-cell *matHeaderCellDef>\n <mat-checkbox (change)=\"$event ? masterToggle() : null\" [checked]=\"selection.hasValue() && isAllSelected()\" [indeterminate]=\"selection.hasValue() && !isAllSelected()\"> </mat-checkbox>\n </mat-header-cell>\n <mat-cell *matCellDef=\"let module\" class=\"module\">\n <mat-checkbox (click)=\"$event.stopPropagation()\" (change)=\"$event ? selection.toggle(module) : null\" [checked]=\"selection.isSelected(module)\"> </mat-checkbox>\n </mat-cell>\n </ng-container>\n\n <ng-container *ngFor=\"let dCol of data.baseData.displayColumns\" [matColumnDef]=\"dCol.displayName\">\n <mat-header-cell *matHeaderCellDef mat-sort-header>\n {{dCol.displayName}}\n </mat-header-cell>\n <mat-cell class=\"entity\" [class.enabled]=\"data.baseData.allowEdit(entity)\" (click)=\"editEntity(entity)\" *matCellDef=\"let entity\">\n {{dCol.value(entity)}}\n </mat-cell>\n </ng-container>\n\n <mat-header-row *matHeaderRowDef=\"displayedColumns\"></mat-header-row>\n <mat-row *matRowDef=\"let row; columns: displayedColumns\"></mat-row>\n </mat-table>\n\n <mat-paginator *ngIf=\"dataSource\" id=\"paginator\" [length]=\"dataSource.filteredData.length\" [pageIndex]=\"0\" [pageSize]=\"10\" [pageSizeOptions]=\"[5, 10, 25, 50]\"> </mat-paginator>\n</div>\n", styles: [".title{text-align:center}button{width:100%}.mat-column-select{flex:0 0 75px}.enabled:hover{cursor:pointer}@media (max-width: 767px){.actions-button,.create-button{margin-bottom:15px}}\n"] }]
|
|
228
|
+
}], ctorParameters: function () { return [{ type: i1.MatDialog }, { type: i0.Injector }]; }, propDecorators: { tableData: [{
|
|
221
229
|
type: Input
|
|
222
230
|
}], paginator: [{
|
|
223
231
|
type: ViewChild,
|
|
@@ -229,4 +237,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImpo
|
|
|
229
237
|
type: ViewChild,
|
|
230
238
|
args: ['filter', { static: true }]
|
|
231
239
|
}] } });
|
|
232
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-material-entity/src/components/table/table.component.ts","../../../../../projects/ngx-material-entity/src/components/table/table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Injector, Input, OnDestroy, OnInit, ViewChild } from '@angular/core';\nimport { MatPaginator } from '@angular/material/paginator';\nimport { MatSort } from '@angular/material/sort';\nimport { MatTableDataSource } from '@angular/material/table';\nimport { EntityService } from '../../classes/entity-service.class';\nimport { firstValueFrom, Subject, takeUntil } from 'rxjs';\nimport { Entity } from '../../classes/entity-model.class';\nimport { SelectionModel } from '@angular/cdk/collections';\nimport { MatDialog } from '@angular/material/dialog';\nimport { NgxMatEntityCreateDialogComponent } from './create-dialog/create-entity-dialog.component';\nimport { CreateEntityDialogData } from './create-dialog/create-entity-dialog-data';\nimport { NgxMatEntityEditDialogComponent } from './edit-dialog/edit-entity-dialog.component';\nimport { EditEntityDialogData } from './edit-dialog/edit-entity-dialog-data';\nimport { MultiSelectAction, EntitiesData, CreateDialogData, EditDialogData } from './table-data';\nimport { NgxMatEntityConfirmDialogComponent } from '../confirm-dialog/confirm-dialog.component';\nimport { ConfirmDialogData } from '../confirm-dialog/confirm-dialog-data';\n\n@Component({\n    selector: 'ngx-mat-entity-table',\n    templateUrl: './table.component.html',\n    styleUrls: ['./table.component.scss']\n})\nexport class NgxMatEntityTableComponent<EntityType extends Entity> implements OnInit, OnDestroy {\n\n    /**\n     * The configuration for the entities-component\n     */\n    @Input()\n    entitiesData!: EntitiesData<EntityType>;\n\n    private entityService!: EntityService<EntityType>;\n    private readonly onDestroy = new Subject<void>();\n    @ViewChild(MatPaginator, { static: true }) paginator!: MatPaginator;\n    @ViewChild(MatSort, { static: true }) sort!: MatSort;\n    @ViewChild('filter', { static: true }) filter!: string;\n    displayedColumns!: string[];\n    dataSource: MatTableDataSource<EntityType> = new MatTableDataSource();\n    selection: SelectionModel<EntityType> = new SelectionModel<EntityType>(true, []);\n\n    constructor(private readonly dialog: MatDialog, private readonly injector: Injector) {}\n\n    ngOnInit(): void {\n        this.validateInput();\n\n        this.entityService = this.injector.get(this.entitiesData.baseData.EntityServiceClass) as EntityService<EntityType>;\n\n        const givenDisplayColumns = this.entitiesData.baseData.displayColumns.map((v) => v.displayName);\n        if (this.entitiesData.baseData.multiSelectActions?.length) {\n            if (givenDisplayColumns.find((s) => s === 'select')) {\n                throw new Error(\n                    `The name \"select\" for a display column is reserved for the multi-select action functionality.\n                    Please choose a different name.`\n                );\n            }\n            this.displayedColumns = ['select'].concat(givenDisplayColumns);\n        }\n        else {\n            this.displayedColumns = givenDisplayColumns;\n        }\n\n        this.dataSource.sortingDataAccessor = (entity: EntityType, header: string) => {\n            return this.entitiesData.baseData.displayColumns.find((dp) => dp.displayName === header)?.value(entity) as string;\n        };\n        this.dataSource.sort = this.sort;\n        if (this.entitiesData.baseData.searchString) {\n            this.dataSource.filterPredicate = (entity: EntityType, filter: string) => {\n                const searchStr = this.entitiesData.baseData.searchString?.(entity) as string;\n                const formattedSearchString = searchStr.toLowerCase();\n                const formattedFilterString = filter.toLowerCase();\n                return formattedSearchString.includes(formattedFilterString);\n            };\n        }\n        this.dataSource.filter = this.filter;\n        this.dataSource.paginator = this.paginator;\n\n        this.entityService.entitiesSubject.pipe(takeUntil(this.onDestroy)).subscribe((entities) => {\n            this.dataSource.data = entities;\n            this.selection.clear();\n        });\n        this.entityService.read();\n    }\n\n    private validateInput(): void {\n        if (!this.entitiesData.baseData.displayColumns) {\n            throw new Error('Missing required Input data \"displayColumns\"');\n        }\n        if (!this.entitiesData.baseData.title) {\n            throw new Error('Missing required Input data \"title\"');\n        }\n        if (!this.entitiesData.baseData.EntityServiceClass) {\n            throw new Error('Missing required Input data \"EntityServiceClass\"');\n        }\n        if (this.entitiesData.baseData.allowCreate === undefined) {\n            this.entitiesData.baseData.allowCreate = true;\n        }\n        if (this.entitiesData.baseData.allowEdit === undefined) {\n            this.entitiesData.baseData.allowEdit = () => true;\n        }\n        if (this.entitiesData.baseData.allowDelete === undefined) {\n            this.entitiesData.baseData.allowDelete = () => true;\n        }\n        if (\n            (\n                this.entitiesData.baseData.allowEdit !== (() => false)\n                || this.entitiesData.baseData.allowDelete !== (() => false)\n                || this.entitiesData.baseData.allowCreate\n            )\n            && !this.entitiesData.baseData.EntityClass\n        ) {\n            throw new Error(`\n                Missing required Input data \"EntityClass\".\n                You can only omit this value if you can neither create or update entities.`\n            );\n        }\n        if (this.entitiesData.baseData.allowCreate && !this.entitiesData.baseData.create && !this.entitiesData.createDialogData) {\n            throw new Error(\n                `Missing required Input data \"createDialogData\".\n                You can only omit this value when creation is disallowed or done with a custom create method.`\n            );\n        }\n        if (\n            (\n                this.entitiesData.baseData.allowEdit !== (() => false)\n                || this.entitiesData.baseData.allowDelete !== (() => false)\n            )\n            && !this.entitiesData.baseData.edit\n            && !this.entitiesData.editDialogData\n        ) {\n            throw new Error(\n                `Missing required Input data \"editDialogData\".\n                You can only omit this value when editing and deleting is disallowed or done with a custom edit method.`\n            );\n        }\n    }\n\n    editEntity(entity: EntityType): void {\n        if (this.entitiesData.baseData.allowEdit?.(entity)) {\n            if (this.entitiesData.baseData.edit) {\n                this.entitiesData.baseData.edit(new this.entitiesData.baseData.EntityClass(entity));\n            }\n            else {\n                this.editDefault(new this.entitiesData.baseData.EntityClass(entity));\n            }\n        }\n    }\n    private editDefault(entity: EntityType): void {\n        const dialogData: EditEntityDialogData<EntityType> = {\n            entity: entity,\n            EntityServiceClass: this.entitiesData.baseData.EntityServiceClass,\n            allowDelete: this.entitiesData.baseData.allowDelete as (entity: EntityType) => boolean,\n            editDialogData: this.entitiesData.editDialogData as EditDialogData<EntityType>\n        };\n        firstValueFrom(\n            this.dialog.open( NgxMatEntityEditDialogComponent, {\n                data: dialogData,\n                minWidth: '60%',\n                autoFocus: false,\n                restoreFocus: false\n            }).afterClosed()\n        ).then((res: number) => {\n            if (res === 0) {\n                const data = this.dataSource.data;\n                data[this.dataSource.data.findIndex((e) => e.id === entity.id)] = entity;\n                this.dataSource.data = data;\n                this.selection.clear();\n            }\n        });\n    }\n\n    createEntity(): void {\n        if (this.entitiesData.baseData.allowCreate) {\n            if (this.entitiesData.baseData.create) {\n                this.entitiesData.baseData.create(new this.entitiesData.baseData.EntityClass());\n            }\n            else {\n                this.createDefault(new this.entitiesData.baseData.EntityClass());\n            }\n        }\n    }\n    private createDefault(entity: EntityType): void {\n        const dialogData: CreateEntityDialogData<EntityType> = {\n            entity: entity,\n            EntityServiceClass: this.entitiesData.baseData.EntityServiceClass,\n            createDialogData: this.entitiesData.createDialogData as CreateDialogData\n        };\n        this.dialog.open(NgxMatEntityCreateDialogComponent, {\n            data: dialogData,\n            minWidth: '60%',\n            autoFocus: false,\n            restoreFocus: false\n        });\n    }\n\n    runMultiAction(action: MultiSelectAction<EntityType>): void {\n        if (!action.requireConfirmDialog || !action.requireConfirmDialog(this.selection.selected)) {\n            return this.confirmRunMultiAction(action);\n        }\n        const dialogData: ConfirmDialogData = {\n            // eslint-disable-next-line max-len\n            text: action.confirmDialogData?.text ? action.confirmDialogData?.text : [`Do you really want to run this action on ${this.selection.selected.length} entries?`],\n            type: 'default',\n            confirmButtonLabel: action.confirmDialogData?.confirmButtonLabel ? action.confirmDialogData?.confirmButtonLabel : 'Confirm',\n            cancelButtonLabel: action.confirmDialogData?.cancelButtonLabel ? action.confirmDialogData?.cancelButtonLabel : 'Cancel',\n            title: action.confirmDialogData?.title ? action.confirmDialogData?.title : action.displayName,\n            requireConfirmation: action.confirmDialogData?.requireConfirmation ? action.confirmDialogData?.requireConfirmation : false,\n            confirmationText: action.confirmDialogData?.confirmationText ? action.confirmDialogData?.confirmationText : undefined\n        };\n        const dialogref = this.dialog.open(NgxMatEntityConfirmDialogComponent, {\n            data: dialogData,\n            autoFocus: false,\n            restoreFocus: false\n        });\n        dialogref.afterClosed().subscribe((res: number) => {\n            if (res === 1) {\n                this.confirmRunMultiAction(action);\n            }\n        });\n    }\n    private confirmRunMultiAction(action: MultiSelectAction<EntityType>): void {\n        action.action(this.selection.selected);\n    }\n\n    multiActionDisabled(action: MultiSelectAction<EntityType>): boolean {\n        if (!this.selection.selected.length) {\n            return true;\n        }\n        if (action.enabled?.(this.selection.selected) === false) {\n            return true;\n        }\n        return false;\n    }\n\n    masterToggle(): void {\n        if (this.isAllSelected()) {\n            this.selection.clear();\n        }\n        else {\n            this.dataSource.data.forEach((row) => this.selection.select(row));\n        }\n    }\n\n    isAllSelected(): boolean {\n        const numSelected = this.selection.selected.length;\n        const numRows = this.dataSource.data.length;\n        return numSelected === numRows;\n    }\n\n    ngOnDestroy(): void {\n        this.onDestroy.next(undefined);\n        this.onDestroy.complete();\n    }\n\n    applyFilter(event: Event): void {\n        const filterValue = (event.target as HTMLInputElement).value;\n        this.dataSource.filter = filterValue.trim().toLowerCase();\n    }\n}","<h1 class=\"title\">{{entitiesData.baseData.title}}</h1>\n\n<div class=\"row\">\n    <mat-form-field class=\"col-lg-8 col-md-6 col-sm-12\">\n        <mat-label>{{entitiesData.baseData.searchLabel ? entitiesData.baseData.searchLabel : 'Search'}}</mat-label>\n        <input matInput (keyup)=\"applyFilter($event)\" />\n    </mat-form-field>\n    <div\n        *ngIf=\"entitiesData.baseData.multiSelectActions?.length\"\n        [class.col-lg-2]=\"entitiesData.baseData.allowCreate\"\n        [class.col-lg-4]=\"!entitiesData.baseData.allowCreate\"\n        [class.col-md-3]=\"entitiesData.baseData.allowCreate\"\n        [class.col-md-6]=\"!entitiesData.baseData.allowCreate\"\n        [class.col-sm-6]=\"entitiesData.baseData.allowCreate\"\n        [class.col-sm-12]=\"!entitiesData.baseData.allowCreate\"\n    >\n        <button class=\"actions-button\" [matMenuTriggerFor]=\"menu\" mat-raised-button>\n            {{entitiesData.baseData.multiSelectLabel ? entitiesData.baseData.multiSelectLabel : 'Actions'}}\n        </button>\n    </div>\n    <mat-menu #menu=\"matMenu\">\n        <button *ngFor=\"let action of entitiesData.baseData.multiSelectActions\" [disabled]=\"multiActionDisabled(action)\" (click)=\"runMultiAction(action)\" mat-menu-item>\n            {{action.displayName}}\n        </button>\n    </mat-menu>\n\n    <div\n        *ngIf=\"entitiesData.baseData.allowCreate\"\n        [class.col-lg-2]=\"entitiesData.baseData.multiSelectActions?.length\"\n        [class.col-lg-4]=\"!entitiesData.baseData.multiSelectActions?.length\"\n        [class.col-md-3]=\"entitiesData.baseData.multiSelectActions?.length\"\n        [class.col-md-6]=\"!entitiesData.baseData.multiSelectActions?.length\"\n        [class.col-sm-6]=\"entitiesData.baseData.multiSelectActions?.length\"\n        [class.col-sm-12]=\"!entitiesData.baseData.multiSelectActions?.length\"\n    >\n        <button class=\"create-button\" (click)=\"createEntity()\" mat-raised-button>\n            {{entitiesData.baseData.createButtonLabel ? entitiesData.baseData.createButtonLabel : 'Create'}}\n        </button>\n    </div>\n</div>\n\n<div class=\"mat-elevation-z8\">\n    <mat-table *ngIf=\"dataSource\" [dataSource]=\"dataSource\" matSort>\n        <!-- select Column -->\n        <ng-container matColumnDef=\"select\">\n            <mat-header-cell *matHeaderCellDef>\n                <mat-checkbox (change)=\"$event ? masterToggle() : null\" [checked]=\"selection.hasValue() && isAllSelected()\" [indeterminate]=\"selection.hasValue() && !isAllSelected()\"> </mat-checkbox>\n            </mat-header-cell>\n            <mat-cell *matCellDef=\"let module\" class=\"module\">\n                <mat-checkbox (click)=\"$event.stopPropagation()\" (change)=\"$event ? selection.toggle(module) : null\" [checked]=\"selection.isSelected(module)\"> </mat-checkbox>\n            </mat-cell>\n        </ng-container>\n\n        <ng-container *ngFor=\"let dCol of entitiesData.baseData.displayColumns\" [matColumnDef]=\"dCol.displayName\">\n            <mat-header-cell *matHeaderCellDef mat-sort-header>\n                {{dCol.displayName}}\n            </mat-header-cell>\n            <mat-cell class=\"entity\" [class.enabled]=\"entitiesData.baseData.allowEdit?.(entity)\" (click)=\"editEntity(entity)\" *matCellDef=\"let entity\">\n                {{dCol.value(entity)}}\n            </mat-cell>\n        </ng-container>\n\n        <mat-header-row *matHeaderRowDef=\"displayedColumns\"></mat-header-row>\n        <mat-row *matRowDef=\"let row; columns: displayedColumns\"></mat-row>\n    </mat-table>\n\n    <mat-paginator *ngIf=\"dataSource\" id=\"paginator\" [length]=\"dataSource.filteredData.length\" [pageIndex]=\"0\" [pageSize]=\"10\" [pageSizeOptions]=\"[5, 10, 25, 50]\"> </mat-paginator>\n</div>\n"]}
|
|
240
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-material-entity/src/components/table/table.component.ts","../../../../../projects/ngx-material-entity/src/components/table/table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Injector, Input, OnDestroy, OnInit, ViewChild } from '@angular/core';\nimport { MatPaginator } from '@angular/material/paginator';\nimport { MatSort } from '@angular/material/sort';\nimport { MatTableDataSource } from '@angular/material/table';\nimport { EntityService } from '../../classes/entity.service';\nimport { firstValueFrom, Subject, takeUntil } from 'rxjs';\nimport { SelectionModel } from '@angular/cdk/collections';\nimport { MatDialog } from '@angular/material/dialog';\nimport { NgxMatEntityCreateDialogComponent } from './create-dialog/create-entity-dialog.component';\nimport { NgxMatEntityEditDialogComponent } from './edit-dialog/edit-entity-dialog.component';\nimport { EditEntityDialogData } from './edit-dialog/edit-entity-dialog-data';\nimport { MultiSelectAction, TableData } from './table-data';\nimport { NgxMatEntityConfirmDialogComponent } from '../confirm-dialog/confirm-dialog.component';\nimport { ConfirmDialogDataBuilder, ConfirmDialogDataInternal } from '../confirm-dialog/confirm-dialog-data.builder';\nimport { CreateEntityDialogDataBuilder, CreateEntityDialogDataInternal } from './create-dialog/create-entity-dialog-data.builder';\nimport { TableDataBuilder, TableDataInternal } from './table-data.builder';\nimport { EditEntityDialogDataBuilder, EditEntityDialogDataInternal } from '../table/edit-dialog/edit-entity-dialog.builder';\n\n/**\n * Generates a fully functional table for displaying, creating, updating and deleting entities\n * based on the configuration passed in the @Input \"tableData\".\n *\n * It offers a lot of customization options which can be found in \"TableData\".\n */\n@Component({\n    selector: 'ngx-mat-entity-table',\n    templateUrl: './table.component.html',\n    styleUrls: ['./table.component.scss']\n})\nexport class NgxMatEntityTableComponent<EntityType extends object> implements OnInit, OnDestroy {\n\n    /**\n     * The configuration for the component.\n     */\n    @Input()\n    tableData!: TableData<EntityType>;\n\n    data!: TableDataInternal<EntityType>;\n\n    private entityService!: EntityService<EntityType>;\n    private readonly onDestroy = new Subject<void>();\n    @ViewChild(MatPaginator, { static: true }) paginator!: MatPaginator;\n    @ViewChild(MatSort, { static: true }) sort!: MatSort;\n    @ViewChild('filter', { static: true }) filter!: string;\n    displayedColumns!: string[];\n    dataSource: MatTableDataSource<EntityType> = new MatTableDataSource();\n    selection: SelectionModel<EntityType> = new SelectionModel<EntityType>(true, []);\n\n    constructor(private readonly dialog: MatDialog, private readonly injector: Injector) {}\n\n    /**\n     * Sets up all the configuration for the table and the EntityService.\n     */\n    ngOnInit(): void {\n        this.data = new TableDataBuilder(this.tableData).getResult();\n\n        this.entityService = this.injector.get(this.data.baseData.EntityServiceClass) as EntityService<EntityType>;\n\n        const givenDisplayColumns = this.data.baseData.displayColumns.map((v) => v.displayName);\n        if (this.data.baseData.multiSelectActions.length) {\n            this.displayedColumns = ['select'].concat(givenDisplayColumns);\n        }\n        else {\n            this.displayedColumns = givenDisplayColumns;\n        }\n\n        this.dataSource.sortingDataAccessor = (entity: EntityType, header: string) => {\n            return this.data.baseData.displayColumns.find((dp) => dp.displayName === header)?.value(entity) as string;\n        };\n        this.dataSource.sort = this.sort;\n        if (this.data.baseData.searchString) {\n            this.dataSource.filterPredicate = (entity: EntityType, filter: string) => {\n                const searchStr = this.data.baseData.searchString(entity) ;\n                const formattedSearchString = searchStr.toLowerCase();\n                const formattedFilterString = filter.toLowerCase();\n                return formattedSearchString.includes(formattedFilterString);\n            };\n        }\n        this.dataSource.filter = this.filter;\n        this.dataSource.paginator = this.paginator;\n\n        this.entityService.entitiesSubject.pipe(takeUntil(this.onDestroy)).subscribe((entities) => {\n            this.dataSource.data = entities;\n            this.selection.clear();\n        });\n        this.entityService.read();\n    }\n\n    /**\n     * Edits an entity. This either calls the edit-Method provided by the user or uses a default edit-dialog.\n     *\n     * @param entity - The entity that should be updated.\n     * @throws When no EntityClass was provided, as a new call is needed to initialize metadata.\n     */\n    editEntity(entity: EntityType): void {\n        if (this.data.baseData.allowEdit(entity)) {\n            if (!this.data.baseData.EntityClass) {\n                throw new Error('No \"EntityClass\" specified for this table');\n            }\n            if (this.data.baseData.edit) {\n                this.data.baseData.edit(new this.data.baseData.EntityClass(entity));\n            }\n            else {\n                this.editDefault(new this.data.baseData.EntityClass(entity));\n            }\n        }\n    }\n\n    private editDefault(entity: EntityType): void {\n        const inputDialogData: EditEntityDialogData<EntityType> = {\n            entity: entity,\n            EntityServiceClass: this.data.baseData.EntityServiceClass,\n            allowDelete: this.data.baseData.allowDelete,\n            editDialogData: this.data.editDialogData\n        }\n        const dialogData: EditEntityDialogDataInternal<EntityType> = new EditEntityDialogDataBuilder(inputDialogData).getResult();\n        firstValueFrom(\n            this.dialog.open(NgxMatEntityEditDialogComponent, {\n                data: dialogData,\n                minWidth: '60%',\n                autoFocus: false,\n                restoreFocus: false\n            }).afterClosed()\n        ).then((res: number) => {\n            if (res === 0) {\n                const data = this.dataSource.data;\n                data[this.dataSource.data.findIndex((e) => e[this.entityService.idKey] === entity[this.entityService.idKey])] = entity;\n                this.dataSource.data = data;\n                this.selection.clear();\n            }\n        });\n    }\n\n    /**\n     * Creates a new Entity. This either calls the create-Method provided by the user or uses a default create-dialog.\n     *\n     * @throws When no EntityClass was provided, as a new call is needed to initialize metadata.\n     */\n    createEntity(): void {\n        if (this.data.baseData.allowCreate) {\n            if (!this.data.baseData.EntityClass) {\n                throw new Error('No \"EntityClass\" specified for this table');\n            }\n            if (this.data.baseData.create) {\n                this.data.baseData.create(new this.data.baseData.EntityClass());\n            }\n            else {\n                this.createDefault(new this.data.baseData.EntityClass());\n            }\n        }\n    }\n\n    private createDefault(entity: EntityType): void {\n        const dialogData: CreateEntityDialogDataInternal<EntityType> = new CreateEntityDialogDataBuilder(\n            {\n                entity: entity,\n                EntityServiceClass: this.data.baseData.EntityServiceClass,\n                createDialogData: this.data.createDialogData\n            }\n        ).getResult();\n        this.dialog.open(NgxMatEntityCreateDialogComponent, {\n            data: dialogData,\n            minWidth: '60%',\n            autoFocus: false,\n            restoreFocus: false\n        });\n    }\n\n    /**\n     * Runs the MultiAction for all selected entries.\n     * Also handles confirmation with an additional dialog if configured.\n     *\n     * @param action - The MultiAction to run.\n     */\n    runMultiAction(action: MultiSelectAction<EntityType>): void {\n        if (!action.requireConfirmDialog || !action.requireConfirmDialog(this.selection.selected)) {\n            return this.confirmRunMultiAction(action);\n        }\n        const dialogData: ConfirmDialogDataInternal = new ConfirmDialogDataBuilder(action.confirmDialogData)\n            .withDefault('text', [`Do you really want to run this action on ${this.selection.selected.length} entries?`])\n            .withDefault('title', action.displayName)\n            .getResult();\n        const dialogRef = this.dialog.open(NgxMatEntityConfirmDialogComponent, {\n            data: dialogData,\n            autoFocus: false,\n            restoreFocus: false\n        });\n        dialogRef.afterClosed().subscribe((res: number) => {\n            if (res === 1) {\n                this.confirmRunMultiAction(action);\n            }\n        });\n    }\n\n    private confirmRunMultiAction(action: MultiSelectAction<EntityType>): void {\n        action.action(this.selection.selected);\n    }\n\n    /**\n     * Checks if an MultiAction is disabled (e.g. Because no entries have been selected).\n     *\n     * @param action - The MultiAction to check.\n     * @returns Whether or not the Action can be used.\n     */\n    multiActionDisabled(action: MultiSelectAction<EntityType>): boolean {\n        if (!this.selection.selected.length) {\n            return true;\n        }\n        if (action.enabled?.(this.selection.selected) === false) {\n            return true;\n        }\n        return false;\n    }\n\n    /**\n     * Toggles all entries in the table.\n     */\n    masterToggle(): void {\n        if (this.isAllSelected()) {\n            this.selection.clear();\n        }\n        else {\n            this.dataSource.data.forEach((row) => this.selection.select(row));\n        }\n    }\n\n    /**\n     * Checks if all entries in the table have been selected.\n     * This is needed to display the \"masterToggle\"-checkbox correctly.\n     *\n     * @returns Whether or not all entries in the table have been selected.\n     */\n    isAllSelected(): boolean {\n        const numSelected = this.selection.selected.length;\n        const numRows = this.dataSource.data.length;\n        return numSelected === numRows;\n    }\n\n    ngOnDestroy(): void {\n        this.onDestroy.next(undefined);\n        this.onDestroy.complete();\n    }\n\n    /**\n     * Applies the search input to filter the table entries.\n     *\n     * @param event - The keyup-event which contains the search-string of the user.\n     */\n    applyFilter(event: Event): void {\n        const filterValue = (event.target as HTMLInputElement).value;\n        this.dataSource.filter = filterValue.trim().toLowerCase();\n    }\n}","<h1 class=\"title\">{{data.baseData.title}}</h1>\n\n<div class=\"row\">\n    <mat-form-field class=\"col-lg-8 col-md-6 col-sm-12\">\n        <mat-label>{{data.baseData.searchLabel}}</mat-label>\n        <input matInput (keyup)=\"applyFilter($event)\" />\n    </mat-form-field>\n    <div\n        *ngIf=\"data.baseData.multiSelectActions.length\"\n        [class.col-lg-2]=\"data.baseData.allowCreate\"\n        [class.col-lg-4]=\"!data.baseData.allowCreate\"\n        [class.col-md-3]=\"data.baseData.allowCreate\"\n        [class.col-md-6]=\"!data.baseData.allowCreate\"\n        [class.col-sm-6]=\"data.baseData.allowCreate\"\n        [class.col-sm-12]=\"!data.baseData.allowCreate\"\n    >\n        <button class=\"actions-button\" [matMenuTriggerFor]=\"menu\" mat-raised-button>\n            {{data.baseData.multiSelectLabel}}\n        </button>\n    </div>\n    <mat-menu #menu=\"matMenu\">\n        <button *ngFor=\"let action of data.baseData.multiSelectActions\" [disabled]=\"multiActionDisabled(action)\" (click)=\"runMultiAction(action)\" mat-menu-item>\n            {{action.displayName}}\n        </button>\n    </mat-menu>\n\n    <div\n        *ngIf=\"data.baseData.allowCreate\"\n        [class.col-lg-2]=\"data.baseData.multiSelectActions.length\"\n        [class.col-lg-4]=\"!data.baseData.multiSelectActions.length\"\n        [class.col-md-3]=\"data.baseData.multiSelectActions.length\"\n        [class.col-md-6]=\"!data.baseData.multiSelectActions.length\"\n        [class.col-sm-6]=\"data.baseData.multiSelectActions.length\"\n        [class.col-sm-12]=\"!data.baseData.multiSelectActions.length\"\n    >\n        <button class=\"create-button\" (click)=\"createEntity()\" mat-raised-button>\n            {{data.baseData.createButtonLabel}}\n        </button>\n    </div>\n</div>\n\n<div class=\"mat-elevation-z8\">\n    <mat-table *ngIf=\"dataSource\" [dataSource]=\"dataSource\" matSort>\n        <!-- select Column -->\n        <ng-container matColumnDef=\"select\">\n            <mat-header-cell *matHeaderCellDef>\n                <mat-checkbox (change)=\"$event ? masterToggle() : null\" [checked]=\"selection.hasValue() && isAllSelected()\" [indeterminate]=\"selection.hasValue() && !isAllSelected()\"> </mat-checkbox>\n            </mat-header-cell>\n            <mat-cell *matCellDef=\"let module\" class=\"module\">\n                <mat-checkbox (click)=\"$event.stopPropagation()\" (change)=\"$event ? selection.toggle(module) : null\" [checked]=\"selection.isSelected(module)\"> </mat-checkbox>\n            </mat-cell>\n        </ng-container>\n\n        <ng-container *ngFor=\"let dCol of data.baseData.displayColumns\" [matColumnDef]=\"dCol.displayName\">\n            <mat-header-cell *matHeaderCellDef mat-sort-header>\n                {{dCol.displayName}}\n            </mat-header-cell>\n            <mat-cell class=\"entity\" [class.enabled]=\"data.baseData.allowEdit(entity)\" (click)=\"editEntity(entity)\" *matCellDef=\"let entity\">\n                {{dCol.value(entity)}}\n            </mat-cell>\n        </ng-container>\n\n        <mat-header-row *matHeaderRowDef=\"displayedColumns\"></mat-header-row>\n        <mat-row *matRowDef=\"let row; columns: displayedColumns\"></mat-row>\n    </mat-table>\n\n    <mat-paginator *ngIf=\"dataSource\" id=\"paginator\" [length]=\"dataSource.filteredData.length\" [pageIndex]=\"0\" [pageSize]=\"10\" [pageSizeOptions]=\"[5, 10, 25, 50]\"> </mat-paginator>\n</div>\n"]}
|
|
@@ -10,6 +10,8 @@ import { MatPaginatorModule } from '@angular/material/paginator';
|
|
|
10
10
|
import { MatButtonModule } from '@angular/material/button';
|
|
11
11
|
import { MatMenuModule } from '@angular/material/menu';
|
|
12
12
|
import { MatDialogModule } from '@angular/material/dialog';
|
|
13
|
+
import { NgxMatEntityCreateDialogModule } from './create-dialog/create-entity-dialog.module';
|
|
14
|
+
import { NgxMatEntityEditDialogModule } from './edit-dialog/edit-entity-dialog.module';
|
|
13
15
|
import * as i0 from "@angular/core";
|
|
14
16
|
export class NgxMatEntityTableModule {
|
|
15
17
|
}
|
|
@@ -23,7 +25,9 @@ NgxMatEntityTableModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0",
|
|
|
23
25
|
MatPaginatorModule,
|
|
24
26
|
MatButtonModule,
|
|
25
27
|
MatMenuModule,
|
|
26
|
-
MatDialogModule
|
|
28
|
+
MatDialogModule,
|
|
29
|
+
NgxMatEntityCreateDialogModule,
|
|
30
|
+
NgxMatEntityEditDialogModule], exports: [NgxMatEntityTableComponent] });
|
|
27
31
|
NgxMatEntityTableModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: NgxMatEntityTableModule, imports: [[
|
|
28
32
|
CommonModule,
|
|
29
33
|
MatInputModule,
|
|
@@ -34,7 +38,9 @@ NgxMatEntityTableModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0",
|
|
|
34
38
|
MatPaginatorModule,
|
|
35
39
|
MatButtonModule,
|
|
36
40
|
MatMenuModule,
|
|
37
|
-
MatDialogModule
|
|
41
|
+
MatDialogModule,
|
|
42
|
+
NgxMatEntityCreateDialogModule,
|
|
43
|
+
NgxMatEntityEditDialogModule,
|
|
38
44
|
]] });
|
|
39
45
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: NgxMatEntityTableModule, decorators: [{
|
|
40
46
|
type: NgModule,
|
|
@@ -50,9 +56,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImpo
|
|
|
50
56
|
MatPaginatorModule,
|
|
51
57
|
MatButtonModule,
|
|
52
58
|
MatMenuModule,
|
|
53
|
-
MatDialogModule
|
|
59
|
+
MatDialogModule,
|
|
60
|
+
NgxMatEntityCreateDialogModule,
|
|
61
|
+
NgxMatEntityEditDialogModule,
|
|
54
62
|
],
|
|
55
63
|
exports: [NgxMatEntityTableComponent]
|
|
56
64
|
}]
|
|
57
65
|
}] });
|
|
58
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
66
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LW1hdGVyaWFsLWVudGl0eS9zcmMvY29tcG9uZW50cy90YWJsZS90YWJsZS5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLDBCQUEwQixFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFDL0QsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ3pELE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUM3QyxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQztBQUNsRSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUMvRCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDekQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sNkJBQTZCLENBQUM7QUFDakUsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQzNELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUN2RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDM0QsT0FBTyxFQUFFLDhCQUE4QixFQUFFLE1BQU0sNkNBQTZDLENBQUM7QUFDN0YsT0FBTyxFQUFFLDRCQUE0QixFQUFFLE1BQU0seUNBQXlDLENBQUM7O0FBb0J2RixNQUFNLE9BQU8sdUJBQXVCOztxSEFBdkIsdUJBQXVCO3NIQUF2Qix1QkFBdUIsaUJBakJqQiwwQkFBMEIsYUFFckMsWUFBWTtRQUNaLGNBQWM7UUFDZCxXQUFXO1FBQ1gsa0JBQWtCO1FBQ2xCLGlCQUFpQjtRQUNqQixjQUFjO1FBQ2Qsa0JBQWtCO1FBQ2xCLGVBQWU7UUFDZixhQUFhO1FBQ2IsZUFBZTtRQUNmLDhCQUE4QjtRQUM5Qiw0QkFBNEIsYUFFdEIsMEJBQTBCO3NIQUUzQix1QkFBdUIsWUFoQnZCO1lBQ0wsWUFBWTtZQUNaLGNBQWM7WUFDZCxXQUFXO1lBQ1gsa0JBQWtCO1lBQ2xCLGlCQUFpQjtZQUNqQixjQUFjO1lBQ2Qsa0JBQWtCO1lBQ2xCLGVBQWU7WUFDZixhQUFhO1lBQ2IsZUFBZTtZQUNmLDhCQUE4QjtZQUM5Qiw0QkFBNEI7U0FDL0I7NEZBR1EsdUJBQXVCO2tCQWxCbkMsUUFBUTttQkFBQztvQkFDTixZQUFZLEVBQUUsQ0FBQywwQkFBMEIsQ0FBQztvQkFDMUMsT0FBTyxFQUFFO3dCQUNMLFlBQVk7d0JBQ1osY0FBYzt3QkFDZCxXQUFXO3dCQUNYLGtCQUFrQjt3QkFDbEIsaUJBQWlCO3dCQUNqQixjQUFjO3dCQUNkLGtCQUFrQjt3QkFDbEIsZUFBZTt3QkFDZixhQUFhO3dCQUNiLGVBQWU7d0JBQ2YsOEJBQThCO3dCQUM5Qiw0QkFBNEI7cUJBQy9CO29CQUNELE9BQU8sRUFBRSxDQUFDLDBCQUEwQixDQUFDO2lCQUN4QyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTmd4TWF0RW50aXR5VGFibGVDb21wb25lbnQgfSBmcm9tICcuL3RhYmxlLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBNYXRJbnB1dE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2lucHV0JztcbmltcG9ydCB7IEZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgTWF0Rm9ybUZpZWxkTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvZm9ybS1maWVsZCc7XG5pbXBvcnQgeyBNYXRDaGVja2JveE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2NoZWNrYm94JztcbmltcG9ydCB7IE1hdFRhYmxlTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvdGFibGUnO1xuaW1wb3J0IHsgTWF0UGFnaW5hdG9yTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvcGFnaW5hdG9yJztcbmltcG9ydCB7IE1hdEJ1dHRvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2J1dHRvbic7XG5pbXBvcnQgeyBNYXRNZW51TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvbWVudSc7XG5pbXBvcnQgeyBNYXREaWFsb2dNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9kaWFsb2cnO1xuaW1wb3J0IHsgTmd4TWF0RW50aXR5Q3JlYXRlRGlhbG9nTW9kdWxlIH0gZnJvbSAnLi9jcmVhdGUtZGlhbG9nL2NyZWF0ZS1lbnRpdHktZGlhbG9nLm1vZHVsZSc7XG5pbXBvcnQgeyBOZ3hNYXRFbnRpdHlFZGl0RGlhbG9nTW9kdWxlIH0gZnJvbSAnLi9lZGl0LWRpYWxvZy9lZGl0LWVudGl0eS1kaWFsb2cubW9kdWxlJztcblxuQE5nTW9kdWxlKHtcbiAgICBkZWNsYXJhdGlvbnM6IFtOZ3hNYXRFbnRpdHlUYWJsZUNvbXBvbmVudF0sXG4gICAgaW1wb3J0czogW1xuICAgICAgICBDb21tb25Nb2R1bGUsXG4gICAgICAgIE1hdElucHV0TW9kdWxlLFxuICAgICAgICBGb3Jtc01vZHVsZSxcbiAgICAgICAgTWF0Rm9ybUZpZWxkTW9kdWxlLFxuICAgICAgICBNYXRDaGVja2JveE1vZHVsZSxcbiAgICAgICAgTWF0VGFibGVNb2R1bGUsXG4gICAgICAgIE1hdFBhZ2luYXRvck1vZHVsZSxcbiAgICAgICAgTWF0QnV0dG9uTW9kdWxlLFxuICAgICAgICBNYXRNZW51TW9kdWxlLFxuICAgICAgICBNYXREaWFsb2dNb2R1bGUsXG4gICAgICAgIE5neE1hdEVudGl0eUNyZWF0ZURpYWxvZ01vZHVsZSxcbiAgICAgICAgTmd4TWF0RW50aXR5RWRpdERpYWxvZ01vZHVsZSxcbiAgICBdLFxuICAgIGV4cG9ydHM6IFtOZ3hNYXRFbnRpdHlUYWJsZUNvbXBvbmVudF1cbn0pXG5leHBvcnQgY2xhc3MgTmd4TWF0RW50aXR5VGFibGVNb2R1bGUge30iXX0=
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { PropertyDecoratorConfigInternal } from '../base/property-decorator-internal.data';
|
|
2
|
+
/**
|
|
3
|
+
* The internal EntityArrayDecoratorConfig. Sets default values.
|
|
4
|
+
*/
|
|
5
|
+
export class EntityArrayDecoratorConfigInternal extends PropertyDecoratorConfigInternal {
|
|
6
|
+
constructor(data) {
|
|
7
|
+
super(data);
|
|
8
|
+
this.createInline = data.createInline != undefined ? data.createInline : true;
|
|
9
|
+
this.displayStyle = data.displayStyle;
|
|
10
|
+
this.itemType = data.itemType;
|
|
11
|
+
this.EntityClass = data.EntityClass;
|
|
12
|
+
this.displayColumns = data.displayColumns;
|
|
13
|
+
this.createInline = data.createInline != undefined ? data.createInline : true;
|
|
14
|
+
this.missingErrorMessage = data.missingErrorMessage ? data.missingErrorMessage : 'Needs to contain at least one value';
|
|
15
|
+
this.defaultWidths = data.defaultWidths ? data.defaultWidths : [12, 12, 12];
|
|
16
|
+
this.addButtonLabel = data.addButtonLabel ? data.addButtonLabel : 'Add';
|
|
17
|
+
this.removeButtonLabel = data.removeButtonLabel ? data.removeButtonLabel : 'Remove';
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
/**
|
|
21
|
+
* The internal StringChipsArrayDecoratorConfig. Sets default values.
|
|
22
|
+
*/
|
|
23
|
+
export class StringChipsArrayDecoratorConfigInternal extends PropertyDecoratorConfigInternal {
|
|
24
|
+
constructor(data) {
|
|
25
|
+
super(data);
|
|
26
|
+
this.deleteIcon = data.deleteIcon ? data.deleteIcon : 'fas fa-circle-minus';
|
|
27
|
+
this.displayStyle = data.displayStyle;
|
|
28
|
+
this.itemType = data.itemType;
|
|
29
|
+
this.maxLength = data.maxLength;
|
|
30
|
+
this.minLength = data.minLength;
|
|
31
|
+
this.regex = data.regex;
|
|
32
|
+
this.defaultWidths = data.defaultWidths ? data.defaultWidths : [6, 12, 12];
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
/**
|
|
36
|
+
* The internal AutocompleteStringChipsArrayDecoratorConfig. Sets default values.
|
|
37
|
+
*/
|
|
38
|
+
export class AutocompleteStringChipsArrayDecoratorConfigInternal extends PropertyDecoratorConfigInternal {
|
|
39
|
+
constructor(data) {
|
|
40
|
+
super(data);
|
|
41
|
+
this.autocompleteValues = data.autocompleteValues;
|
|
42
|
+
this.deleteIcon = data.deleteIcon ? data.deleteIcon : 'fas fa-circle-minus';
|
|
43
|
+
this.displayStyle = data.displayStyle;
|
|
44
|
+
this.itemType = data.itemType;
|
|
45
|
+
this.maxLength = data.maxLength;
|
|
46
|
+
this.minLength = data.minLength;
|
|
47
|
+
this.regex = data.regex;
|
|
48
|
+
this.defaultWidths = data.defaultWidths ? data.defaultWidths : [6, 12, 12];
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"array-decorator-internal.data.js","sourceRoot":"","sources":["../../../../../projects/ngx-material-entity/src/decorators/array/array-decorator-internal.data.ts"],"names":[],"mappings":"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","sourcesContent":["import { CreateDialogData } from '../../components/table/table-data';\nimport { EntityClassNewable } from '../../classes/entity.model';\nimport { DecoratorTypes } from '../base/decorator-types.enum';\nimport { PropertyDecoratorConfigInternal } from '../base/property-decorator-internal.data';\nimport { ArrayTableDisplayColumn, AutocompleteStringChipsArrayDecoratorConfig, EntityArrayDecoratorConfig, StringChipsArrayDecoratorConfig } from './array-decorator.data';\n\n/**\n * The internal EntityArrayDecoratorConfig. Sets default values.\n */\nexport class EntityArrayDecoratorConfigInternal<EntityType extends object>\n    extends PropertyDecoratorConfigInternal implements EntityArrayDecoratorConfig<EntityType> {\n\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    itemType: DecoratorTypes.OBJECT;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    displayStyle: 'table';\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    EntityClass: EntityClassNewable<EntityType>;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    displayColumns: ArrayTableDisplayColumn<EntityType>[];\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    createDialogData?: CreateDialogData;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    createInline: boolean;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    missingErrorMessage: string;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    addButtonLabel: string;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    removeButtonLabel: string;\n\n    constructor(data: EntityArrayDecoratorConfig<EntityType>) {\n        super(data);\n        this.createInline = data.createInline != undefined ? data.createInline : true;\n        this.displayStyle = data.displayStyle;\n        this.itemType = data.itemType;\n        this.EntityClass = data.EntityClass;\n        this.displayColumns = data.displayColumns;\n        this.createInline = data.createInline != undefined ? data.createInline : true;\n        this.missingErrorMessage = data.missingErrorMessage ? data.missingErrorMessage : 'Needs to contain at least one value';\n        this.defaultWidths = data.defaultWidths ? data.defaultWidths : [12, 12, 12];\n        this.addButtonLabel = data.addButtonLabel ? data.addButtonLabel: 'Add'\n        this.removeButtonLabel = data.removeButtonLabel ? data.removeButtonLabel: 'Remove'\n    }\n}\n\n/**\n * The internal StringChipsArrayDecoratorConfig. Sets default values.\n */\nexport class StringChipsArrayDecoratorConfigInternal extends PropertyDecoratorConfigInternal implements StringChipsArrayDecoratorConfig {\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    itemType: DecoratorTypes.STRING;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    displayStyle: 'chips';\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    deleteIcon: string;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    minLength?: number;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    maxLength?: number;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    regex?: RegExp;\n\n    constructor(data: StringChipsArrayDecoratorConfig) {\n        super(data);\n        this.deleteIcon = data.deleteIcon ? data.deleteIcon : 'fas fa-circle-minus';\n        this.displayStyle = data.displayStyle;\n        this.itemType = data.itemType;\n        this.maxLength = data.maxLength;\n        this.minLength = data.minLength;\n        this.regex = data.regex;\n        this.defaultWidths = data.defaultWidths ? data.defaultWidths : [6, 12, 12];\n    }\n}\n\n/**\n * The internal AutocompleteStringChipsArrayDecoratorConfig. Sets default values.\n */\nexport class AutocompleteStringChipsArrayDecoratorConfigInternal\n    extends PropertyDecoratorConfigInternal implements AutocompleteStringChipsArrayDecoratorConfig {\n\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    autocompleteValues: string[];\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    itemType: DecoratorTypes.STRING_AUTOCOMPLETE;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    displayStyle: 'chips';\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    deleteIcon: string;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    minLength?: number;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    maxLength?: number;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    regex?: RegExp;\n\n    constructor(data: AutocompleteStringChipsArrayDecoratorConfig) {\n        super(data);\n        this.autocompleteValues = data.autocompleteValues;\n        this.deleteIcon = data.deleteIcon ? data.deleteIcon : 'fas fa-circle-minus'\n        this.displayStyle = data.displayStyle;\n        this.itemType = data.itemType;\n        this.maxLength = data.maxLength;\n        this.minLength = data.minLength;\n        this.regex = data.regex;\n        this.defaultWidths = data.defaultWidths ? data.defaultWidths : [6, 12, 12];\n    }\n}"]}
|