ngx-material-entity 0.1.0
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 +93 -0
- package/LICENSE.md +21 -0
- package/README.md +691 -0
- package/classes/entity-model.class.d.ts +9 -0
- package/classes/entity-service.class.d.ts +56 -0
- package/classes/entity-utilities.class.d.ts +95 -0
- package/components/confirm-dialog/confirm-dialog-data.d.ts +41 -0
- package/components/confirm-dialog/confirm-dialog.component.d.ts +18 -0
- package/components/confirm-dialog/confirm-dialog.module.d.ts +12 -0
- package/components/get-validation-error-message.function.d.ts +7 -0
- package/components/input/array-table/add-array-item-dialog/add-array-item-dialog.component.d.ts +35 -0
- package/components/input/array-table/add-array-item-dialog/add-array-item-dialog.module.d.ts +12 -0
- package/components/input/array-table/array-table.component.d.ts +34 -0
- package/components/input/array-table/array-table.module.d.ts +19 -0
- package/components/input/input.component.d.ts +73 -0
- package/components/input/input.module.d.ts +18 -0
- package/components/input/internal-input/internal-input.component.d.ts +57 -0
- package/components/input/internal-input/internal-input.module.d.ts +16 -0
- package/components/table/create-dialog/create-entity-dialog-data.d.ts +21 -0
- package/components/table/create-dialog/create-entity-dialog.component.d.ts +25 -0
- package/components/table/create-dialog/create-entity-dialog.module.d.ts +12 -0
- package/components/table/edit-dialog/edit-entity-dialog-data.d.ts +25 -0
- package/components/table/edit-dialog/edit-entity-dialog.component.d.ts +28 -0
- package/components/table/edit-dialog/edit-entity-dialog.module.d.ts +13 -0
- package/components/table/table-data.d.ts +184 -0
- package/components/table/table.component.d.ts +41 -0
- package/components/table/table.module.d.ts +17 -0
- package/decorators/array.decorator.d.ts +125 -0
- package/decorators/base/base-property.decorator.d.ts +9 -0
- package/decorators/base/decorator-types.enum.d.ts +28 -0
- package/decorators/base/property-decorator-config.interface.d.ts +50 -0
- package/decorators/boolean.decorator.d.ts +42 -0
- package/decorators/number.decorator.d.ts +40 -0
- package/decorators/object.decorator.d.ts +27 -0
- package/decorators/string.decorator.d.ts +76 -0
- package/esm2020/classes/entity-model.class.mjs +19 -0
- package/esm2020/classes/entity-service.class.mjs +70 -0
- package/esm2020/classes/entity-utilities.class.mjs +296 -0
- package/esm2020/components/confirm-dialog/confirm-dialog-data.mjs +2 -0
- package/esm2020/components/confirm-dialog/confirm-dialog.component.mjs +51 -0
- package/esm2020/components/confirm-dialog/confirm-dialog.module.mjs +22 -0
- package/esm2020/components/get-validation-error-message.function.mjs +32 -0
- package/esm2020/components/input/array-table/add-array-item-dialog/add-array-item-dialog.component.mjs +43 -0
- package/esm2020/components/input/array-table/add-array-item-dialog/add-array-item-dialog.module.mjs +22 -0
- package/esm2020/components/input/array-table/array-table.component.mjs +116 -0
- package/esm2020/components/input/array-table/array-table.module.mjs +66 -0
- package/esm2020/components/input/input.component.mjs +158 -0
- package/esm2020/components/input/input.module.mjs +62 -0
- package/esm2020/components/input/internal-input/internal-input.component.mjs +73 -0
- package/esm2020/components/input/internal-input/internal-input.module.mjs +54 -0
- package/esm2020/components/table/create-dialog/create-entity-dialog-data.mjs +2 -0
- package/esm2020/components/table/create-dialog/create-entity-dialog.component.mjs +77 -0
- package/esm2020/components/table/create-dialog/create-entity-dialog.module.mjs +22 -0
- package/esm2020/components/table/edit-dialog/edit-entity-dialog-data.mjs +2 -0
- package/esm2020/components/table/edit-dialog/edit-entity-dialog.component.mjs +112 -0
- package/esm2020/components/table/edit-dialog/edit-entity-dialog.module.mjs +42 -0
- package/esm2020/components/table/table-data.mjs +2 -0
- package/esm2020/components/table/table.component.mjs +232 -0
- package/esm2020/components/table/table.module.mjs +58 -0
- package/esm2020/decorators/array.decorator.mjs +70 -0
- package/esm2020/decorators/base/base-property.decorator.mjs +13 -0
- package/esm2020/decorators/base/decorator-types.enum.mjs +20 -0
- package/esm2020/decorators/base/property-decorator-config.interface.mjs +31 -0
- package/esm2020/decorators/boolean.decorator.mjs +44 -0
- package/esm2020/decorators/number.decorator.mjs +36 -0
- package/esm2020/decorators/object.decorator.mjs +23 -0
- package/esm2020/decorators/string.decorator.mjs +61 -0
- package/esm2020/ngx-material-entity.mjs +5 -0
- package/esm2020/public-api.mjs +32 -0
- package/fesm2015/ngx-material-entity.mjs +1786 -0
- package/fesm2015/ngx-material-entity.mjs.map +1 -0
- package/fesm2020/ngx-material-entity.mjs +1760 -0
- package/fesm2020/ngx-material-entity.mjs.map +1 -0
- package/ngx-material-entity.d.ts +5 -0
- package/package.json +40 -0
- package/public-api.d.ts +25 -0
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { MatInputModule } from '@angular/material/input';
|
|
4
|
+
import { FormsModule } from '@angular/forms';
|
|
5
|
+
import { MatFormFieldModule } from '@angular/material/form-field';
|
|
6
|
+
import { MatSelectModule } from '@angular/material/select';
|
|
7
|
+
import { MatAutocompleteModule } from '@angular/material/autocomplete';
|
|
8
|
+
import { MatCheckboxModule } from '@angular/material/checkbox';
|
|
9
|
+
import { MatSlideToggleModule } from '@angular/material/slide-toggle';
|
|
10
|
+
import { MatTableModule } from '@angular/material/table';
|
|
11
|
+
import { NgxMatEntityInternalInputComponent } from './internal-input.component';
|
|
12
|
+
import * as i0 from "@angular/core";
|
|
13
|
+
export class NgxMatEntityInternalInputModule {
|
|
14
|
+
}
|
|
15
|
+
NgxMatEntityInternalInputModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: NgxMatEntityInternalInputModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
16
|
+
NgxMatEntityInternalInputModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: NgxMatEntityInternalInputModule, declarations: [NgxMatEntityInternalInputComponent], imports: [CommonModule,
|
|
17
|
+
MatInputModule,
|
|
18
|
+
FormsModule,
|
|
19
|
+
MatFormFieldModule,
|
|
20
|
+
MatSelectModule,
|
|
21
|
+
MatAutocompleteModule,
|
|
22
|
+
MatCheckboxModule,
|
|
23
|
+
MatSlideToggleModule,
|
|
24
|
+
MatTableModule], exports: [NgxMatEntityInternalInputComponent] });
|
|
25
|
+
NgxMatEntityInternalInputModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: NgxMatEntityInternalInputModule, imports: [[
|
|
26
|
+
CommonModule,
|
|
27
|
+
MatInputModule,
|
|
28
|
+
FormsModule,
|
|
29
|
+
MatFormFieldModule,
|
|
30
|
+
MatSelectModule,
|
|
31
|
+
MatAutocompleteModule,
|
|
32
|
+
MatCheckboxModule,
|
|
33
|
+
MatSlideToggleModule,
|
|
34
|
+
MatTableModule
|
|
35
|
+
]] });
|
|
36
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: NgxMatEntityInternalInputModule, decorators: [{
|
|
37
|
+
type: NgModule,
|
|
38
|
+
args: [{
|
|
39
|
+
declarations: [NgxMatEntityInternalInputComponent],
|
|
40
|
+
imports: [
|
|
41
|
+
CommonModule,
|
|
42
|
+
MatInputModule,
|
|
43
|
+
FormsModule,
|
|
44
|
+
MatFormFieldModule,
|
|
45
|
+
MatSelectModule,
|
|
46
|
+
MatAutocompleteModule,
|
|
47
|
+
MatCheckboxModule,
|
|
48
|
+
MatSlideToggleModule,
|
|
49
|
+
MatTableModule
|
|
50
|
+
],
|
|
51
|
+
exports: [NgxMatEntityInternalInputComponent]
|
|
52
|
+
}]
|
|
53
|
+
}] });
|
|
54
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZXJuYWwtaW5wdXQubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LW1hdGVyaWFsLWVudGl0eS9zcmMvY29tcG9uZW50cy9pbnB1dC9pbnRlcm5hbC1pbnB1dC9pbnRlcm5hbC1pbnB1dC5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ3pELE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUM3QyxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQztBQUNsRSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDM0QsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFDdkUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFDL0QsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFDdEUsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ3pELE9BQU8sRUFBRSxrQ0FBa0MsRUFBRSxNQUFNLDRCQUE0QixDQUFDOztBQWlCaEYsTUFBTSxPQUFPLCtCQUErQjs7NkhBQS9CLCtCQUErQjs4SEFBL0IsK0JBQStCLGlCQWR6QixrQ0FBa0MsYUFFN0MsWUFBWTtRQUNaLGNBQWM7UUFDZCxXQUFXO1FBQ1gsa0JBQWtCO1FBQ2xCLGVBQWU7UUFDZixxQkFBcUI7UUFDckIsaUJBQWlCO1FBQ2pCLG9CQUFvQjtRQUNwQixjQUFjLGFBRVIsa0NBQWtDOzhIQUVuQywrQkFBK0IsWUFiL0I7WUFDTCxZQUFZO1lBQ1osY0FBYztZQUNkLFdBQVc7WUFDWCxrQkFBa0I7WUFDbEIsZUFBZTtZQUNmLHFCQUFxQjtZQUNyQixpQkFBaUI7WUFDakIsb0JBQW9CO1lBQ3BCLGNBQWM7U0FDakI7NEZBR1EsK0JBQStCO2tCQWYzQyxRQUFRO21CQUFDO29CQUNOLFlBQVksRUFBRSxDQUFDLGtDQUFrQyxDQUFDO29CQUNsRCxPQUFPLEVBQUU7d0JBQ0wsWUFBWTt3QkFDWixjQUFjO3dCQUNkLFdBQVc7d0JBQ1gsa0JBQWtCO3dCQUNsQixlQUFlO3dCQUNmLHFCQUFxQjt3QkFDckIsaUJBQWlCO3dCQUNqQixvQkFBb0I7d0JBQ3BCLGNBQWM7cUJBQ2pCO29CQUNELE9BQU8sRUFBRSxDQUFDLGtDQUFrQyxDQUFDO2lCQUNoRCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTWF0SW5wdXRNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9pbnB1dCc7XG5pbXBvcnQgeyBGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7IE1hdEZvcm1GaWVsZE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2Zvcm0tZmllbGQnO1xuaW1wb3J0IHsgTWF0U2VsZWN0TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvc2VsZWN0JztcbmltcG9ydCB7IE1hdEF1dG9jb21wbGV0ZU1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2F1dG9jb21wbGV0ZSc7XG5pbXBvcnQgeyBNYXRDaGVja2JveE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2NoZWNrYm94JztcbmltcG9ydCB7IE1hdFNsaWRlVG9nZ2xlTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvc2xpZGUtdG9nZ2xlJztcbmltcG9ydCB7IE1hdFRhYmxlTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvdGFibGUnO1xuaW1wb3J0IHsgTmd4TWF0RW50aXR5SW50ZXJuYWxJbnB1dENvbXBvbmVudCB9IGZyb20gJy4vaW50ZXJuYWwtaW5wdXQuY29tcG9uZW50JztcblxuQE5nTW9kdWxlKHtcbiAgICBkZWNsYXJhdGlvbnM6IFtOZ3hNYXRFbnRpdHlJbnRlcm5hbElucHV0Q29tcG9uZW50XSxcbiAgICBpbXBvcnRzOiBbXG4gICAgICAgIENvbW1vbk1vZHVsZSxcbiAgICAgICAgTWF0SW5wdXRNb2R1bGUsXG4gICAgICAgIEZvcm1zTW9kdWxlLFxuICAgICAgICBNYXRGb3JtRmllbGRNb2R1bGUsXG4gICAgICAgIE1hdFNlbGVjdE1vZHVsZSxcbiAgICAgICAgTWF0QXV0b2NvbXBsZXRlTW9kdWxlLFxuICAgICAgICBNYXRDaGVja2JveE1vZHVsZSxcbiAgICAgICAgTWF0U2xpZGVUb2dnbGVNb2R1bGUsXG4gICAgICAgIE1hdFRhYmxlTW9kdWxlXG4gICAgXSxcbiAgICBleHBvcnRzOiBbTmd4TWF0RW50aXR5SW50ZXJuYWxJbnB1dENvbXBvbmVudF1cbn0pXG5leHBvcnQgY2xhc3MgTmd4TWF0RW50aXR5SW50ZXJuYWxJbnB1dE1vZHVsZSB7fSJdfQ==
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3JlYXRlLWVudGl0eS1kaWFsb2ctZGF0YS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1tYXRlcmlhbC1lbnRpdHkvc3JjL2NvbXBvbmVudHMvdGFibGUvY3JlYXRlLWRpYWxvZy9jcmVhdGUtZW50aXR5LWRpYWxvZy1kYXRhLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBIdHRwQ2xpZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uL2h0dHAnO1xuaW1wb3J0IHsgRW50aXR5U2VydmljZSB9IGZyb20gJy4uLy4uLy4uL2NsYXNzZXMvZW50aXR5LXNlcnZpY2UuY2xhc3MnO1xuaW1wb3J0IHsgRW50aXR5IH0gZnJvbSAnLi4vLi4vLi4vY2xhc3Nlcy9lbnRpdHktbW9kZWwuY2xhc3MnO1xuaW1wb3J0IHsgQ3JlYXRlRGlhbG9nRGF0YSB9IGZyb20gJy4uL3RhYmxlLWRhdGEnO1xuXG4vKipcbiAqIFRoZSBEZWZpbml0aW9uIG9mIHRoZSBDcmVhdGUgRW50aXR5IERpYWxvZyBEYXRhXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgQ3JlYXRlRW50aXR5RGlhbG9nRGF0YTxFbnRpdHlUeXBlIGV4dGVuZHMgRW50aXR5PiB7XG4gICAgLyoqXG4gICAgICogQW4gZW1wdHkgZW50aXR5IHRoYXQgaXMgdXNlZCBhcyB0aGUgZGF0YSBtb2RlbC5cbiAgICAgKi9cbiAgICBlbnRpdHk6IEVudGl0eVR5cGUsXG4gICAgLyoqXG4gICAgICogVGhlIEVudGl0eSBTZXJ2aWNlIGNsYXNzIHVzZWQgZm9yIHRoZSBjcmVhdGUgcmVxdWVzdC5cbiAgICAgKi9cbiAgICBFbnRpdHlTZXJ2aWNlQ2xhc3M6IG5ldyAoaHR0cENsaWVudDogSHR0cENsaWVudCkgPT4gRW50aXR5U2VydmljZTxFbnRpdHlUeXBlPixcbiAgICAvKipcbiAgICAgKiBUaGUgaW5mbyBvZiB0aGUgZ2VuZXJpYyBjcmVhdGUtZGlhbG9nLlxuICAgICAqL1xuICAgIGNyZWF0ZURpYWxvZ0RhdGE6IENyZWF0ZURpYWxvZ0RhdGFcbn0iXX0=
|
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
import { Component, Inject, Injector } from '@angular/core';
|
|
2
|
+
import { MatDialog, MatDialogRef, MAT_DIALOG_DATA } from '@angular/material/dialog';
|
|
3
|
+
import { EntityUtilities } from '../../../classes/entity-utilities.class';
|
|
4
|
+
import { NgxMatEntityConfirmDialogComponent } from '../../confirm-dialog/confirm-dialog.component';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "@angular/material/dialog";
|
|
7
|
+
import * as i2 from "../../input/input.component";
|
|
8
|
+
import * as i3 from "@angular/material/button";
|
|
9
|
+
import * as i4 from "@angular/forms";
|
|
10
|
+
import * as i5 from "@angular/common";
|
|
11
|
+
export class NgxMatEntityCreateDialogComponent {
|
|
12
|
+
constructor(data, dialogRef, injector, dialog) {
|
|
13
|
+
this.data = data;
|
|
14
|
+
this.dialogRef = dialogRef;
|
|
15
|
+
this.injector = injector;
|
|
16
|
+
this.dialog = dialog;
|
|
17
|
+
this.EntityUtilities = EntityUtilities;
|
|
18
|
+
this.getWidth = EntityUtilities.getWidth;
|
|
19
|
+
}
|
|
20
|
+
ngOnInit() {
|
|
21
|
+
this.dialogRef.disableClose = true;
|
|
22
|
+
this.setEntityKeys();
|
|
23
|
+
this.entityService = this.injector.get(this.data.EntityServiceClass);
|
|
24
|
+
}
|
|
25
|
+
setEntityKeys() {
|
|
26
|
+
this.entityKeys = Reflect.ownKeys(this.data.entity);
|
|
27
|
+
const omitCreateKeys = EntityUtilities.getOmitForCreate(this.data.entity);
|
|
28
|
+
this.entityKeys = this.entityKeys.filter((k) => !omitCreateKeys.includes(k))
|
|
29
|
+
.sort((a, b) => EntityUtilities.compareOrder(a, b, this.data.entity));
|
|
30
|
+
}
|
|
31
|
+
create() {
|
|
32
|
+
if (this.data.createDialogData.createRequiresConfirmDialog === false) {
|
|
33
|
+
return this.confirmCreate();
|
|
34
|
+
}
|
|
35
|
+
const dialogData = {
|
|
36
|
+
// eslint-disable-next-line max-len
|
|
37
|
+
text: this.data.createDialogData.confirmCreateDialogData?.text ? this.data.createDialogData.confirmCreateDialogData?.text : ['Do you really want to create this entity?'],
|
|
38
|
+
type: 'default',
|
|
39
|
+
// eslint-disable-next-line max-len
|
|
40
|
+
confirmButtonLabel: this.data.createDialogData.confirmCreateDialogData?.confirmButtonLabel ? this.data.createDialogData.confirmCreateDialogData?.confirmButtonLabel : 'Create',
|
|
41
|
+
// eslint-disable-next-line max-len
|
|
42
|
+
cancelButtonLabel: this.data.createDialogData.confirmCreateDialogData?.cancelButtonLabel ? this.data.createDialogData.confirmCreateDialogData?.cancelButtonLabel : 'Cancel',
|
|
43
|
+
// eslint-disable-next-line max-len
|
|
44
|
+
title: this.data.createDialogData.confirmCreateDialogData?.title ? this.data.createDialogData.confirmCreateDialogData?.title : 'Create',
|
|
45
|
+
// eslint-disable-next-line max-len
|
|
46
|
+
requireConfirmation: this.data.createDialogData.confirmCreateDialogData?.requireConfirmation ? this.data.createDialogData.confirmCreateDialogData?.requireConfirmation : false,
|
|
47
|
+
// eslint-disable-next-line max-len
|
|
48
|
+
confirmationText: this.data.createDialogData.confirmCreateDialogData?.confirmationText ? this.data.createDialogData.confirmCreateDialogData?.confirmationText : undefined,
|
|
49
|
+
};
|
|
50
|
+
const dialogref = this.dialog.open(NgxMatEntityConfirmDialogComponent, {
|
|
51
|
+
data: dialogData,
|
|
52
|
+
autoFocus: false,
|
|
53
|
+
restoreFocus: false
|
|
54
|
+
});
|
|
55
|
+
dialogref.afterClosed().subscribe((res) => {
|
|
56
|
+
if (res === 1) {
|
|
57
|
+
this.confirmCreate();
|
|
58
|
+
}
|
|
59
|
+
});
|
|
60
|
+
}
|
|
61
|
+
confirmCreate() {
|
|
62
|
+
this.entityService.create(this.data.entity).then(() => this.dialogRef.close());
|
|
63
|
+
}
|
|
64
|
+
cancel() {
|
|
65
|
+
this.dialogRef.close();
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
NgxMatEntityCreateDialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: NgxMatEntityCreateDialogComponent, deps: [{ token: MAT_DIALOG_DATA }, { token: i1.MatDialogRef }, { token: i0.Injector }, { token: i1.MatDialog }], target: i0.ɵɵFactoryTarget.Component });
|
|
69
|
+
NgxMatEntityCreateDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: NgxMatEntityCreateDialogComponent, selector: "ngx-mat-entity-create-dialog", ngImport: i0, template: "<h2 mat-dialog-title>{{data.createDialogData.title}}</h2>\n\n<mat-dialog-content>\n <form #form=\"ngForm\" class=\"row\">\n <ngx-mat-entity-input\n *ngFor=\"let key of entityKeys\"\n [entity]=\"data.entity\"\n [propertyKey]=\"key\"\n [hideOmitForCreate]=\"true\"\n class=\"col-lg-{{getWidth(data.entity, key, 'lg')}} col-md-{{getWidth(data.entity, key, 'md')}} col-sm-{{getWidth(data.entity, key, 'sm')}}\"\n >\n </ngx-mat-entity-input>\n </form>\n</mat-dialog-content>\n\n<mat-dialog-actions>\n <button mat-raised-button (click)=\"create()\" [disabled]=\"!EntityUtilities.isEntityValid(data.entity, 'create')\">\n {{data.createDialogData.createButtonLabel ? data.createDialogData.createButtonLabel : 'Create'}}\n </button>\n <button mat-raised-button (click)=\"cancel()\" class=\"cancel-button\">\n {{data.createDialogData.cancelButtonLabel ? data.createDialogData.cancelButtonLabel : 'Cancel'}}\n </button>\n</mat-dialog-actions>\n", styles: ["mat-dialog-actions{display:flex;justify-content:space-between}\n"], components: [{ type: i2.NgxMatEntityInputComponent, selector: "ngx-mat-entity-input", inputs: ["entity", "propertyKey", "getValidationErrorMessage", "hideOmitForCreate", "hideOmitForEdit"] }, { 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"] }], directives: [{ type: i1.MatDialogTitle, selector: "[mat-dialog-title], [matDialogTitle]", inputs: ["id"], exportAs: ["matDialogTitle"] }, { type: i1.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { type: i4.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { type: i4.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i4.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i1.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]" }] });
|
|
70
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: NgxMatEntityCreateDialogComponent, decorators: [{
|
|
71
|
+
type: Component,
|
|
72
|
+
args: [{ selector: 'ngx-mat-entity-create-dialog', template: "<h2 mat-dialog-title>{{data.createDialogData.title}}</h2>\n\n<mat-dialog-content>\n <form #form=\"ngForm\" class=\"row\">\n <ngx-mat-entity-input\n *ngFor=\"let key of entityKeys\"\n [entity]=\"data.entity\"\n [propertyKey]=\"key\"\n [hideOmitForCreate]=\"true\"\n class=\"col-lg-{{getWidth(data.entity, key, 'lg')}} col-md-{{getWidth(data.entity, key, 'md')}} col-sm-{{getWidth(data.entity, key, 'sm')}}\"\n >\n </ngx-mat-entity-input>\n </form>\n</mat-dialog-content>\n\n<mat-dialog-actions>\n <button mat-raised-button (click)=\"create()\" [disabled]=\"!EntityUtilities.isEntityValid(data.entity, 'create')\">\n {{data.createDialogData.createButtonLabel ? data.createDialogData.createButtonLabel : 'Create'}}\n </button>\n <button mat-raised-button (click)=\"cancel()\" class=\"cancel-button\">\n {{data.createDialogData.cancelButtonLabel ? data.createDialogData.cancelButtonLabel : 'Cancel'}}\n </button>\n</mat-dialog-actions>\n", styles: ["mat-dialog-actions{display:flex;justify-content:space-between}\n"] }]
|
|
73
|
+
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
74
|
+
type: Inject,
|
|
75
|
+
args: [MAT_DIALOG_DATA]
|
|
76
|
+
}] }, { type: i1.MatDialogRef }, { type: i0.Injector }, { type: i1.MatDialog }]; } });
|
|
77
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-entity-dialog.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-material-entity/src/components/table/create-dialog/create-entity-dialog.component.ts","../../../../../../projects/ngx-material-entity/src/components/table/create-dialog/create-entity-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Inject, Injector, OnInit } from '@angular/core';\nimport { MatDialog, MatDialogRef, MAT_DIALOG_DATA } from '@angular/material/dialog';\nimport { EntityService } from '../../../classes/entity-service.class';\nimport { Entity } from '../../../classes/entity-model.class';\nimport { EntityUtilities } from '../../../classes/entity-utilities.class';\nimport { CreateEntityDialogData } from './create-entity-dialog-data';\nimport { ConfirmDialogData } from '../../confirm-dialog/confirm-dialog-data';\nimport { NgxMatEntityConfirmDialogComponent } from '../../confirm-dialog/confirm-dialog.component';\n\n@Component({\n    selector: 'ngx-mat-entity-create-dialog',\n    templateUrl: './create-entity-dialog.component.html',\n    styleUrls: ['./create-entity-dialog.component.scss']\n})\nexport class NgxMatEntityCreateDialogComponent<EntityType extends Entity> implements OnInit {\n    EntityUtilities = EntityUtilities;\n\n    entityKeys!: (keyof EntityType)[];\n\n    entityService!: EntityService<EntityType>;\n\n    getWidth = EntityUtilities.getWidth;\n\n    constructor(\n        @Inject(MAT_DIALOG_DATA)\n        public data: CreateEntityDialogData<EntityType>,\n        public dialogRef: MatDialogRef<NgxMatEntityCreateDialogComponent<EntityType>>,\n        private readonly injector: Injector,\n        private readonly dialog: MatDialog\n    ) { }\n\n    ngOnInit(): void {\n        this.dialogRef.disableClose = true;\n        this.setEntityKeys();\n        this.entityService = this.injector.get(this.data.EntityServiceClass) as EntityService<EntityType>;\n    }\n\n    private setEntityKeys(): void {\n        this.entityKeys = Reflect.ownKeys(this.data.entity) as (keyof EntityType)[];\n        const omitCreateKeys = EntityUtilities.getOmitForCreate(this.data.entity);\n        this.entityKeys = this.entityKeys.filter((k) => !omitCreateKeys.includes(k))\n            .sort((a, b) => EntityUtilities.compareOrder(a, b, this.data.entity));\n    }\n\n    create(): void {\n        if (this.data.createDialogData.createRequiresConfirmDialog === false) {\n            return this.confirmCreate();\n        }\n        const dialogData: ConfirmDialogData = {\n            // eslint-disable-next-line max-len\n            text: this.data.createDialogData.confirmCreateDialogData?.text ? this.data.createDialogData.confirmCreateDialogData?.text : ['Do you really want to create this entity?'],\n            type: 'default',\n            // eslint-disable-next-line max-len\n            confirmButtonLabel: this.data.createDialogData.confirmCreateDialogData?.confirmButtonLabel ? this.data.createDialogData.confirmCreateDialogData?.confirmButtonLabel : 'Create',\n            // eslint-disable-next-line max-len\n            cancelButtonLabel: this.data.createDialogData.confirmCreateDialogData?.cancelButtonLabel ? this.data.createDialogData.confirmCreateDialogData?.cancelButtonLabel : 'Cancel',\n            // eslint-disable-next-line max-len\n            title: this.data.createDialogData.confirmCreateDialogData?.title ? this.data.createDialogData.confirmCreateDialogData?.title : 'Create',\n            // eslint-disable-next-line max-len\n            requireConfirmation: this.data.createDialogData.confirmCreateDialogData?.requireConfirmation ? this.data.createDialogData.confirmCreateDialogData?.requireConfirmation : false,\n            // eslint-disable-next-line max-len\n            confirmationText: this.data.createDialogData.confirmCreateDialogData?.confirmationText ? this.data.createDialogData.confirmCreateDialogData?.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.confirmCreate();\n            }\n        });\n    }\n    private confirmCreate(): void {\n        this.entityService.create(this.data.entity).then(() => this.dialogRef.close());\n    }\n\n    cancel(): void {\n        this.dialogRef.close();\n    }\n}","<h2 mat-dialog-title>{{data.createDialogData.title}}</h2>\n\n<mat-dialog-content>\n    <form #form=\"ngForm\" class=\"row\">\n        <ngx-mat-entity-input\n            *ngFor=\"let key of entityKeys\"\n            [entity]=\"data.entity\"\n            [propertyKey]=\"key\"\n            [hideOmitForCreate]=\"true\"\n            class=\"col-lg-{{getWidth(data.entity, key, 'lg')}} col-md-{{getWidth(data.entity, key, 'md')}} col-sm-{{getWidth(data.entity, key, 'sm')}}\"\n        >\n        </ngx-mat-entity-input>\n    </form>\n</mat-dialog-content>\n\n<mat-dialog-actions>\n    <button mat-raised-button (click)=\"create()\" [disabled]=\"!EntityUtilities.isEntityValid(data.entity, 'create')\">\n        {{data.createDialogData.createButtonLabel ? data.createDialogData.createButtonLabel : 'Create'}}\n    </button>\n    <button mat-raised-button (click)=\"cancel()\" class=\"cancel-button\">\n        {{data.createDialogData.cancelButtonLabel ? data.createDialogData.cancelButtonLabel : 'Cancel'}}\n    </button>\n</mat-dialog-actions>\n"]}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { NgxMatEntityCreateDialogComponent } from './create-entity-dialog.component';
|
|
4
|
+
import { NgxMatEntityInputModule } from '../../input/input.module';
|
|
5
|
+
import { MatDialogModule } from '@angular/material/dialog';
|
|
6
|
+
import { FormsModule } from '@angular/forms';
|
|
7
|
+
import { MatButtonModule } from '@angular/material/button';
|
|
8
|
+
import * as i0 from "@angular/core";
|
|
9
|
+
export class NgxMatEntityCreateDialogModule {
|
|
10
|
+
}
|
|
11
|
+
NgxMatEntityCreateDialogModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: NgxMatEntityCreateDialogModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
12
|
+
NgxMatEntityCreateDialogModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: NgxMatEntityCreateDialogModule, declarations: [NgxMatEntityCreateDialogComponent], imports: [CommonModule, NgxMatEntityInputModule, MatDialogModule, FormsModule, MatButtonModule], exports: [NgxMatEntityCreateDialogComponent] });
|
|
13
|
+
NgxMatEntityCreateDialogModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: NgxMatEntityCreateDialogModule, imports: [[CommonModule, NgxMatEntityInputModule, MatDialogModule, FormsModule, MatButtonModule]] });
|
|
14
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: NgxMatEntityCreateDialogModule, decorators: [{
|
|
15
|
+
type: NgModule,
|
|
16
|
+
args: [{
|
|
17
|
+
declarations: [NgxMatEntityCreateDialogComponent],
|
|
18
|
+
imports: [CommonModule, NgxMatEntityInputModule, MatDialogModule, FormsModule, MatButtonModule],
|
|
19
|
+
exports: [NgxMatEntityCreateDialogComponent]
|
|
20
|
+
}]
|
|
21
|
+
}] });
|
|
22
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3JlYXRlLWVudGl0eS1kaWFsb2cubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LW1hdGVyaWFsLWVudGl0eS9zcmMvY29tcG9uZW50cy90YWJsZS9jcmVhdGUtZGlhbG9nL2NyZWF0ZS1lbnRpdHktZGlhbG9nLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsaUNBQWlDLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUNyRixPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUNuRSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDM0QsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQzdDLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQzs7QUFPM0QsTUFBTSxPQUFPLDhCQUE4Qjs7NEhBQTlCLDhCQUE4Qjs2SEFBOUIsOEJBQThCLGlCQUp4QixpQ0FBaUMsYUFDdEMsWUFBWSxFQUFFLHVCQUF1QixFQUFFLGVBQWUsRUFBRSxXQUFXLEVBQUUsZUFBZSxhQUNwRixpQ0FBaUM7NkhBRWxDLDhCQUE4QixZQUg5QixDQUFDLFlBQVksRUFBRSx1QkFBdUIsRUFBRSxlQUFlLEVBQUUsV0FBVyxFQUFFLGVBQWUsQ0FBQzs0RkFHdEYsOEJBQThCO2tCQUwxQyxRQUFRO21CQUFDO29CQUNOLFlBQVksRUFBRSxDQUFDLGlDQUFpQyxDQUFDO29CQUNqRCxPQUFPLEVBQUUsQ0FBQyxZQUFZLEVBQUUsdUJBQXVCLEVBQUUsZUFBZSxFQUFFLFdBQVcsRUFBRSxlQUFlLENBQUM7b0JBQy9GLE9BQU8sRUFBRSxDQUFDLGlDQUFpQyxDQUFDO2lCQUMvQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTmd4TWF0RW50aXR5Q3JlYXRlRGlhbG9nQ29tcG9uZW50IH0gZnJvbSAnLi9jcmVhdGUtZW50aXR5LWRpYWxvZy5jb21wb25lbnQnO1xuaW1wb3J0IHsgTmd4TWF0RW50aXR5SW5wdXRNb2R1bGUgfSBmcm9tICcuLi8uLi9pbnB1dC9pbnB1dC5tb2R1bGUnO1xuaW1wb3J0IHsgTWF0RGlhbG9nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvZGlhbG9nJztcbmltcG9ydCB7IEZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgTWF0QnV0dG9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvYnV0dG9uJztcblxuQE5nTW9kdWxlKHtcbiAgICBkZWNsYXJhdGlvbnM6IFtOZ3hNYXRFbnRpdHlDcmVhdGVEaWFsb2dDb21wb25lbnRdLFxuICAgIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIE5neE1hdEVudGl0eUlucHV0TW9kdWxlLCBNYXREaWFsb2dNb2R1bGUsIEZvcm1zTW9kdWxlLCBNYXRCdXR0b25Nb2R1bGVdLFxuICAgIGV4cG9ydHM6IFtOZ3hNYXRFbnRpdHlDcmVhdGVEaWFsb2dDb21wb25lbnRdXG59KVxuZXhwb3J0IGNsYXNzIE5neE1hdEVudGl0eUNyZWF0ZURpYWxvZ01vZHVsZSB7fSJdfQ==
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWRpdC1lbnRpdHktZGlhbG9nLWRhdGEuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtbWF0ZXJpYWwtZW50aXR5L3NyYy9jb21wb25lbnRzL3RhYmxlL2VkaXQtZGlhbG9nL2VkaXQtZW50aXR5LWRpYWxvZy1kYXRhLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBIdHRwQ2xpZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uL2h0dHAnO1xuaW1wb3J0IHsgRW50aXR5U2VydmljZSB9IGZyb20gJy4uLy4uLy4uL2NsYXNzZXMvZW50aXR5LXNlcnZpY2UuY2xhc3MnO1xuaW1wb3J0IHsgRW50aXR5IH0gZnJvbSAnLi4vLi4vLi4vY2xhc3Nlcy9lbnRpdHktbW9kZWwuY2xhc3MnO1xuaW1wb3J0IHsgRWRpdERpYWxvZ0RhdGEgfSBmcm9tICcuLi90YWJsZS1kYXRhJztcblxuLyoqXG4gKiBUaGUgRGVmaW5pdGlvbiBvZiB0aGUgRWRpdCBFbnRpdHkgRGlhbG9nIERhdGFcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBFZGl0RW50aXR5RGlhbG9nRGF0YTxFbnRpdHlUeXBlIGV4dGVuZHMgRW50aXR5PiB7XG4gICAgLyoqXG4gICAgICogVGhlIGVudGl0eSB0byBlZGl0XG4gICAgICovXG4gICAgZW50aXR5OiBFbnRpdHlUeXBlLFxuICAgIC8qKlxuICAgICAqIFRoZSBFbnRpdHkgU2VydmljZSBjbGFzcyB1c2VkIGZvciB1cGRhdGluZy9kZWxldGluZyB0aGUgZW50aXR5LlxuICAgICAqL1xuICAgIEVudGl0eVNlcnZpY2VDbGFzczogbmV3IChodHRwQ2xpZW50OiBIdHRwQ2xpZW50KSA9PiBFbnRpdHlTZXJ2aWNlPEVudGl0eVR5cGU+LFxuICAgIC8qKlxuICAgICAqIFRoZSBpbmZvIG9mIHRoZSBnZW5lcmljIGVkaXQtZGlhbG9nLlxuICAgICAqL1xuICAgIGVkaXREaWFsb2dEYXRhOiBFZGl0RGlhbG9nRGF0YTxFbnRpdHlUeXBlPixcbiAgICAvKipcbiAgICAgKiBXaGV0aGVyIG9yIG5vdCB0aGUgdXNlciBjYW4gZGVsZXRlIHRoaXMgc3BlY2lmaWMgZW50aXR5XG4gICAgICovXG4gICAgYWxsb3dEZWxldGU6IChlbnRpdHk6IEVudGl0eVR5cGUpID0+IGJvb2xlYW5cbn0iXX0=
|
|
@@ -0,0 +1,112 @@
|
|
|
1
|
+
import { Component, Inject, Injector } from '@angular/core';
|
|
2
|
+
import { MatDialog, MatDialogRef, MAT_DIALOG_DATA } from '@angular/material/dialog';
|
|
3
|
+
import { EntityUtilities } from '../../../classes/entity-utilities.class';
|
|
4
|
+
import { cloneDeep } from 'lodash';
|
|
5
|
+
import { NgxMatEntityConfirmDialogComponent } from '../../confirm-dialog/confirm-dialog.component';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
import * as i1 from "@angular/material/dialog";
|
|
8
|
+
import * as i2 from "@angular/material/button";
|
|
9
|
+
import * as i3 from "../../input/input.component";
|
|
10
|
+
import * as i4 from "@angular/common";
|
|
11
|
+
import * as i5 from "@angular/forms";
|
|
12
|
+
export class NgxMatEntityEditDialogComponent {
|
|
13
|
+
constructor(data, dialogRef, injector, dialog) {
|
|
14
|
+
this.data = data;
|
|
15
|
+
this.dialogRef = dialogRef;
|
|
16
|
+
this.injector = injector;
|
|
17
|
+
this.dialog = dialog;
|
|
18
|
+
this.EntityUtilities = EntityUtilities;
|
|
19
|
+
this.getWidth = EntityUtilities.getWidth;
|
|
20
|
+
}
|
|
21
|
+
ngOnInit() {
|
|
22
|
+
this.dialogRef.disableClose = true;
|
|
23
|
+
this.setEntityKeys();
|
|
24
|
+
this.entityService = this.injector.get(this.data.EntityServiceClass);
|
|
25
|
+
this.entityPriorChanges = cloneDeep(this.data.entity);
|
|
26
|
+
}
|
|
27
|
+
setEntityKeys() {
|
|
28
|
+
this.entityKeys = Reflect.ownKeys(this.data.entity);
|
|
29
|
+
const omitUpdateKeys = EntityUtilities.getOmitForUpdate(this.data.entity);
|
|
30
|
+
this.entityKeys = this.entityKeys.filter((k) => !omitUpdateKeys.includes(k))
|
|
31
|
+
.sort((a, b) => EntityUtilities.compareOrder(a, b, this.data.entity));
|
|
32
|
+
}
|
|
33
|
+
edit() {
|
|
34
|
+
if (this.data.editDialogData.editRequiresConfirmDialog === false) {
|
|
35
|
+
return this.confirmEdit();
|
|
36
|
+
}
|
|
37
|
+
const dialogData = {
|
|
38
|
+
// eslint-disable-next-line max-len
|
|
39
|
+
text: this.data.editDialogData.confirmEditDialogData?.text ? this.data.editDialogData.confirmEditDialogData?.text : ['Do you really want to save all changes?'],
|
|
40
|
+
type: 'default',
|
|
41
|
+
// eslint-disable-next-line max-len
|
|
42
|
+
confirmButtonLabel: this.data.editDialogData.confirmEditDialogData?.confirmButtonLabel ? this.data.editDialogData.confirmEditDialogData?.confirmButtonLabel : 'Confirm',
|
|
43
|
+
// eslint-disable-next-line max-len
|
|
44
|
+
cancelButtonLabel: this.data.editDialogData.confirmEditDialogData?.cancelButtonLabel ? this.data.editDialogData.confirmEditDialogData?.cancelButtonLabel : 'Cancel',
|
|
45
|
+
title: this.data.editDialogData.confirmEditDialogData?.title ? this.data.editDialogData.confirmEditDialogData?.title : 'Edit',
|
|
46
|
+
// eslint-disable-next-line max-len
|
|
47
|
+
requireConfirmation: this.data.editDialogData.confirmEditDialogData?.requireConfirmation ? this.data.editDialogData.confirmEditDialogData?.requireConfirmation : false,
|
|
48
|
+
// eslint-disable-next-line max-len
|
|
49
|
+
confirmationText: this.data.editDialogData.confirmEditDialogData?.confirmationText ? this.data.editDialogData.confirmEditDialogData?.confirmationText : undefined,
|
|
50
|
+
};
|
|
51
|
+
const dialogref = this.dialog.open(NgxMatEntityConfirmDialogComponent, {
|
|
52
|
+
data: dialogData,
|
|
53
|
+
autoFocus: false,
|
|
54
|
+
restoreFocus: false
|
|
55
|
+
});
|
|
56
|
+
dialogref.afterClosed().subscribe((res) => {
|
|
57
|
+
if (res === 1) {
|
|
58
|
+
this.confirmEdit();
|
|
59
|
+
}
|
|
60
|
+
});
|
|
61
|
+
}
|
|
62
|
+
confirmEdit() {
|
|
63
|
+
this.entityService.update(this.data.entity, this.entityPriorChanges).then(() => this.dialogRef.close(1));
|
|
64
|
+
}
|
|
65
|
+
delete() {
|
|
66
|
+
if (this.data.editDialogData.deleteRequiresConfirmDialog === false) {
|
|
67
|
+
return this.confirmDelete();
|
|
68
|
+
}
|
|
69
|
+
const dialogData = {
|
|
70
|
+
// eslint-disable-next-line max-len
|
|
71
|
+
text: this.data.editDialogData.confirmDeleteDialogData?.text ? this.data.editDialogData.confirmDeleteDialogData?.text : ['Do you really want to delete this entity?'],
|
|
72
|
+
type: 'delete',
|
|
73
|
+
// eslint-disable-next-line max-len
|
|
74
|
+
confirmButtonLabel: this.data.editDialogData.confirmDeleteDialogData?.confirmButtonLabel ? this.data.editDialogData.confirmDeleteDialogData?.confirmButtonLabel : 'Delete',
|
|
75
|
+
// eslint-disable-next-line max-len
|
|
76
|
+
cancelButtonLabel: this.data.editDialogData.confirmDeleteDialogData?.cancelButtonLabel ? this.data.editDialogData.confirmDeleteDialogData?.cancelButtonLabel : 'Cancel',
|
|
77
|
+
// eslint-disable-next-line max-len
|
|
78
|
+
title: this.data.editDialogData.confirmDeleteDialogData?.title ? this.data.editDialogData.confirmDeleteDialogData?.title : 'Delete',
|
|
79
|
+
// eslint-disable-next-line max-len
|
|
80
|
+
requireConfirmation: this.data.editDialogData.confirmDeleteDialogData?.requireConfirmation ? this.data.editDialogData.confirmDeleteDialogData?.requireConfirmation : false,
|
|
81
|
+
// eslint-disable-next-line max-len
|
|
82
|
+
confirmationText: this.data.editDialogData.confirmDeleteDialogData?.confirmationText ? this.data.editDialogData.confirmDeleteDialogData?.confirmationText : undefined,
|
|
83
|
+
};
|
|
84
|
+
const dialogref = this.dialog.open(NgxMatEntityConfirmDialogComponent, {
|
|
85
|
+
data: dialogData,
|
|
86
|
+
autoFocus: false,
|
|
87
|
+
restoreFocus: false
|
|
88
|
+
});
|
|
89
|
+
dialogref.afterClosed().subscribe((res) => {
|
|
90
|
+
if (res === 1) {
|
|
91
|
+
this.confirmDelete();
|
|
92
|
+
}
|
|
93
|
+
});
|
|
94
|
+
}
|
|
95
|
+
confirmDelete() {
|
|
96
|
+
this.entityService.delete(this.entityPriorChanges.id).then(() => this.dialogRef.close(2));
|
|
97
|
+
}
|
|
98
|
+
cancel() {
|
|
99
|
+
EntityUtilities.resetChangesOnEntity(this.data.entity, this.entityPriorChanges);
|
|
100
|
+
this.dialogRef.close(0);
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
NgxMatEntityEditDialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: NgxMatEntityEditDialogComponent, deps: [{ token: MAT_DIALOG_DATA }, { token: i1.MatDialogRef }, { token: i0.Injector }, { token: i1.MatDialog }], target: i0.ɵɵFactoryTarget.Component });
|
|
104
|
+
NgxMatEntityEditDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: NgxMatEntityEditDialogComponent, selector: "ngx-mat-entity-edit-dialog", ngImport: i0, template: "<h2 mat-dialog-title>\n {{data.editDialogData.title(data.entity)}}\n <button *ngIf=\"data.allowDelete(data.entity)\" mat-raised-button (click)=\"delete()\" color=\"warn\" class=\"delete-button\" tabindex=\"-1\">\n {{data.editDialogData.deleteButtonLabel ? data.editDialogData.deleteButtonLabel : 'Delete'}}\n </button>\n</h2>\n\n<mat-dialog-content>\n <form #form=\"ngForm\" class=\"row\">\n <ngx-mat-entity-input\n *ngFor=\"let key of entityKeys\"\n [entity]=\"data.entity\"\n [propertyKey]=\"key\"\n [hideOmitForEdit]=\"true\"\n class=\"col-lg-{{getWidth(data.entity, key, 'lg')}} col-md-{{getWidth(data.entity, key, 'md')}} col-sm-{{getWidth(data.entity, key, 'sm')}}\"\n >\n </ngx-mat-entity-input>\n </form>\n</mat-dialog-content>\n\n<mat-dialog-actions>\n <button mat-raised-button (click)=\"edit()\" [disabled]=\"!EntityUtilities.isEntityValid(data.entity, 'edit') || !EntityUtilities.dirty(data.entity, entityPriorChanges)\">\n {{data.editDialogData.confirmButtonLabel ? data.editDialogData.confirmButtonLabel : 'Save'}}\n </button>\n <button mat-raised-button (click)=\"cancel()\" class=\"cancel-button\">\n {{data.editDialogData.cancelButtonLabel ? data.editDialogData.cancelButtonLabel : 'Cancel'}}\n </button>\n</mat-dialog-actions>\n", styles: ["mat-dialog-actions{display:flex;justify-content:space-between}.delete-button{float:right}\n"], components: [{ type: i2.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: i3.NgxMatEntityInputComponent, selector: "ngx-mat-entity-input", inputs: ["entity", "propertyKey", "getValidationErrorMessage", "hideOmitForCreate", "hideOmitForEdit"] }], directives: [{ type: i1.MatDialogTitle, selector: "[mat-dialog-title], [matDialogTitle]", inputs: ["id"], exportAs: ["matDialogTitle"] }, { type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { type: i5.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { type: i5.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i5.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i1.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]" }] });
|
|
105
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: NgxMatEntityEditDialogComponent, decorators: [{
|
|
106
|
+
type: Component,
|
|
107
|
+
args: [{ selector: 'ngx-mat-entity-edit-dialog', template: "<h2 mat-dialog-title>\n {{data.editDialogData.title(data.entity)}}\n <button *ngIf=\"data.allowDelete(data.entity)\" mat-raised-button (click)=\"delete()\" color=\"warn\" class=\"delete-button\" tabindex=\"-1\">\n {{data.editDialogData.deleteButtonLabel ? data.editDialogData.deleteButtonLabel : 'Delete'}}\n </button>\n</h2>\n\n<mat-dialog-content>\n <form #form=\"ngForm\" class=\"row\">\n <ngx-mat-entity-input\n *ngFor=\"let key of entityKeys\"\n [entity]=\"data.entity\"\n [propertyKey]=\"key\"\n [hideOmitForEdit]=\"true\"\n class=\"col-lg-{{getWidth(data.entity, key, 'lg')}} col-md-{{getWidth(data.entity, key, 'md')}} col-sm-{{getWidth(data.entity, key, 'sm')}}\"\n >\n </ngx-mat-entity-input>\n </form>\n</mat-dialog-content>\n\n<mat-dialog-actions>\n <button mat-raised-button (click)=\"edit()\" [disabled]=\"!EntityUtilities.isEntityValid(data.entity, 'edit') || !EntityUtilities.dirty(data.entity, entityPriorChanges)\">\n {{data.editDialogData.confirmButtonLabel ? data.editDialogData.confirmButtonLabel : 'Save'}}\n </button>\n <button mat-raised-button (click)=\"cancel()\" class=\"cancel-button\">\n {{data.editDialogData.cancelButtonLabel ? data.editDialogData.cancelButtonLabel : 'Cancel'}}\n </button>\n</mat-dialog-actions>\n", styles: ["mat-dialog-actions{display:flex;justify-content:space-between}.delete-button{float:right}\n"] }]
|
|
108
|
+
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
109
|
+
type: Inject,
|
|
110
|
+
args: [MAT_DIALOG_DATA]
|
|
111
|
+
}] }, { type: i1.MatDialogRef }, { type: i0.Injector }, { type: i1.MatDialog }]; } });
|
|
112
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"edit-entity-dialog.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-material-entity/src/components/table/edit-dialog/edit-entity-dialog.component.ts","../../../../../../projects/ngx-material-entity/src/components/table/edit-dialog/edit-entity-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Inject, Injector, OnInit } from '@angular/core';\nimport { MatDialog, MatDialogRef, MAT_DIALOG_DATA } from '@angular/material/dialog';\nimport { EntityService } from '../../../classes/entity-service.class';\nimport { Entity } from '../../../classes/entity-model.class';\nimport { EntityUtilities } from '../../../classes/entity-utilities.class';\nimport { cloneDeep } from 'lodash';\nimport { EditEntityDialogData } from './edit-entity-dialog-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-edit-dialog',\n    templateUrl: './edit-entity-dialog.component.html',\n    styleUrls: ['./edit-entity-dialog.component.scss']\n})\nexport class  NgxMatEntityEditDialogComponent<EntityType extends Entity> implements OnInit {\n    EntityUtilities = EntityUtilities;\n\n    entityKeys!: (keyof EntityType)[];\n\n    entityService!: EntityService<EntityType>;\n\n    entityPriorChanges!: EntityType;\n\n    getWidth = EntityUtilities.getWidth;\n\n    constructor(\n        @Inject(MAT_DIALOG_DATA)\n        public data: EditEntityDialogData<EntityType>,\n        public dialogRef: MatDialogRef<NgxMatEntityEditDialogComponent<EntityType>>,\n        private readonly injector: Injector,\n        private readonly dialog: MatDialog\n    ) { }\n\n    ngOnInit(): void {\n        this.dialogRef.disableClose = true;\n        this.setEntityKeys();\n        this.entityService = this.injector.get(this.data.EntityServiceClass) as EntityService<EntityType>;\n        this.entityPriorChanges = cloneDeep(this.data.entity);\n    }\n\n    private setEntityKeys(): void {\n        this.entityKeys = Reflect.ownKeys(this.data.entity) as (keyof EntityType)[];\n        const omitUpdateKeys = EntityUtilities.getOmitForUpdate(this.data.entity);\n        this.entityKeys = this.entityKeys.filter((k) => !omitUpdateKeys.includes(k))\n            .sort((a, b) => EntityUtilities.compareOrder(a, b, this.data.entity));\n    }\n\n    edit(): void {\n        if (this.data.editDialogData.editRequiresConfirmDialog === false) {\n            return this.confirmEdit();\n        }\n        const dialogData: ConfirmDialogData = {\n            // eslint-disable-next-line max-len\n            text: this.data.editDialogData.confirmEditDialogData?.text ? this.data.editDialogData.confirmEditDialogData?.text : ['Do you really want to save all changes?'],\n            type: 'default',\n            // eslint-disable-next-line max-len\n            confirmButtonLabel: this.data.editDialogData.confirmEditDialogData?.confirmButtonLabel ? this.data.editDialogData.confirmEditDialogData?.confirmButtonLabel : 'Confirm',\n            // eslint-disable-next-line max-len\n            cancelButtonLabel: this.data.editDialogData.confirmEditDialogData?.cancelButtonLabel ? this.data.editDialogData.confirmEditDialogData?.cancelButtonLabel : 'Cancel',\n            title: this.data.editDialogData.confirmEditDialogData?.title ? this.data.editDialogData.confirmEditDialogData?.title : 'Edit',\n            // eslint-disable-next-line max-len\n            requireConfirmation: this.data.editDialogData.confirmEditDialogData?.requireConfirmation ? this.data.editDialogData.confirmEditDialogData?.requireConfirmation : false,\n            // eslint-disable-next-line max-len\n            confirmationText: this.data.editDialogData.confirmEditDialogData?.confirmationText ? this.data.editDialogData.confirmEditDialogData?.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.confirmEdit();\n            }\n        });\n    }\n    private confirmEdit(): void {\n        this.entityService.update(this.data.entity, this.entityPriorChanges).then(() => this.dialogRef.close(1));\n    }\n\n    delete(): void {\n        if (this.data.editDialogData.deleteRequiresConfirmDialog === false) {\n            return this.confirmDelete();\n        }\n        const dialogData: ConfirmDialogData = {\n            // eslint-disable-next-line max-len\n            text: this.data.editDialogData.confirmDeleteDialogData?.text ? this.data.editDialogData.confirmDeleteDialogData?.text : ['Do you really want to delete this entity?'],\n            type: 'delete',\n            // eslint-disable-next-line max-len\n            confirmButtonLabel: this.data.editDialogData.confirmDeleteDialogData?.confirmButtonLabel ? this.data.editDialogData.confirmDeleteDialogData?.confirmButtonLabel : 'Delete',\n            // eslint-disable-next-line max-len\n            cancelButtonLabel: this.data.editDialogData.confirmDeleteDialogData?.cancelButtonLabel ? this.data.editDialogData.confirmDeleteDialogData?.cancelButtonLabel : 'Cancel',\n            // eslint-disable-next-line max-len\n            title: this.data.editDialogData.confirmDeleteDialogData?.title ? this.data.editDialogData.confirmDeleteDialogData?.title : 'Delete',\n            // eslint-disable-next-line max-len\n            requireConfirmation: this.data.editDialogData.confirmDeleteDialogData?.requireConfirmation ? this.data.editDialogData.confirmDeleteDialogData?.requireConfirmation : false,\n            // eslint-disable-next-line max-len\n            confirmationText: this.data.editDialogData.confirmDeleteDialogData?.confirmationText ? this.data.editDialogData.confirmDeleteDialogData?.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.confirmDelete();\n            }\n        });\n    }\n    private confirmDelete(): void {\n        this.entityService.delete(this.entityPriorChanges.id).then(() => this.dialogRef.close(2));\n    }\n\n    cancel(): void {\n        EntityUtilities.resetChangesOnEntity(this.data.entity, this.entityPriorChanges);\n        this.dialogRef.close(0);\n    }\n}","<h2 mat-dialog-title>\n    {{data.editDialogData.title(data.entity)}}\n    <button *ngIf=\"data.allowDelete(data.entity)\" mat-raised-button (click)=\"delete()\" color=\"warn\" class=\"delete-button\" tabindex=\"-1\">\n        {{data.editDialogData.deleteButtonLabel ? data.editDialogData.deleteButtonLabel : 'Delete'}}\n    </button>\n</h2>\n\n<mat-dialog-content>\n    <form #form=\"ngForm\" class=\"row\">\n        <ngx-mat-entity-input\n            *ngFor=\"let key of entityKeys\"\n            [entity]=\"data.entity\"\n            [propertyKey]=\"key\"\n            [hideOmitForEdit]=\"true\"\n            class=\"col-lg-{{getWidth(data.entity, key, 'lg')}} col-md-{{getWidth(data.entity, key, 'md')}} col-sm-{{getWidth(data.entity, key, 'sm')}}\"\n        >\n        </ngx-mat-entity-input>\n    </form>\n</mat-dialog-content>\n\n<mat-dialog-actions>\n    <button mat-raised-button (click)=\"edit()\" [disabled]=\"!EntityUtilities.isEntityValid(data.entity, 'edit') || !EntityUtilities.dirty(data.entity, entityPriorChanges)\">\n        {{data.editDialogData.confirmButtonLabel ? data.editDialogData.confirmButtonLabel : 'Save'}}\n    </button>\n    <button mat-raised-button (click)=\"cancel()\" class=\"cancel-button\">\n        {{data.editDialogData.cancelButtonLabel ? data.editDialogData.cancelButtonLabel : 'Cancel'}}\n    </button>\n</mat-dialog-actions>\n"]}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { NgxMatEntityEditDialogComponent } from './edit-entity-dialog.component';
|
|
4
|
+
import { NgxMatEntityInputModule } from '../../input/input.module';
|
|
5
|
+
import { MatDialogModule } from '@angular/material/dialog';
|
|
6
|
+
import { FormsModule } from '@angular/forms';
|
|
7
|
+
import { MatButtonModule } from '@angular/material/button';
|
|
8
|
+
import { NgxMatEntityConfirmDialogModule } from '../../confirm-dialog/confirm-dialog.module';
|
|
9
|
+
import * as i0 from "@angular/core";
|
|
10
|
+
export class NgxMatEntityEditDialogModule {
|
|
11
|
+
}
|
|
12
|
+
NgxMatEntityEditDialogModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: NgxMatEntityEditDialogModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
13
|
+
NgxMatEntityEditDialogModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: NgxMatEntityEditDialogModule, declarations: [NgxMatEntityEditDialogComponent], imports: [CommonModule,
|
|
14
|
+
NgxMatEntityInputModule,
|
|
15
|
+
MatDialogModule,
|
|
16
|
+
FormsModule,
|
|
17
|
+
MatButtonModule,
|
|
18
|
+
NgxMatEntityConfirmDialogModule], exports: [NgxMatEntityEditDialogComponent] });
|
|
19
|
+
NgxMatEntityEditDialogModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: NgxMatEntityEditDialogModule, imports: [[
|
|
20
|
+
CommonModule,
|
|
21
|
+
NgxMatEntityInputModule,
|
|
22
|
+
MatDialogModule,
|
|
23
|
+
FormsModule,
|
|
24
|
+
MatButtonModule,
|
|
25
|
+
NgxMatEntityConfirmDialogModule
|
|
26
|
+
]] });
|
|
27
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: NgxMatEntityEditDialogModule, decorators: [{
|
|
28
|
+
type: NgModule,
|
|
29
|
+
args: [{
|
|
30
|
+
declarations: [NgxMatEntityEditDialogComponent],
|
|
31
|
+
imports: [
|
|
32
|
+
CommonModule,
|
|
33
|
+
NgxMatEntityInputModule,
|
|
34
|
+
MatDialogModule,
|
|
35
|
+
FormsModule,
|
|
36
|
+
MatButtonModule,
|
|
37
|
+
NgxMatEntityConfirmDialogModule
|
|
38
|
+
],
|
|
39
|
+
exports: [NgxMatEntityEditDialogComponent]
|
|
40
|
+
}]
|
|
41
|
+
}] });
|
|
42
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWRpdC1lbnRpdHktZGlhbG9nLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1tYXRlcmlhbC1lbnRpdHkvc3JjL2NvbXBvbmVudHMvdGFibGUvZWRpdC1kaWFsb2cvZWRpdC1lbnRpdHktZGlhbG9nLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsK0JBQStCLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUNqRixPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUNuRSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDM0QsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQzdDLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsK0JBQStCLEVBQUUsTUFBTSw0Q0FBNEMsQ0FBQzs7QUFjN0YsTUFBTSxPQUFPLDRCQUE0Qjs7MEhBQTVCLDRCQUE0QjsySEFBNUIsNEJBQTRCLGlCQVhyQiwrQkFBK0IsYUFFM0MsWUFBWTtRQUNaLHVCQUF1QjtRQUN2QixlQUFlO1FBQ2YsV0FBVztRQUNYLGVBQWU7UUFDZiwrQkFBK0IsYUFFeEIsK0JBQStCOzJIQUVqQyw0QkFBNEIsWUFWNUI7WUFDTCxZQUFZO1lBQ1osdUJBQXVCO1lBQ3ZCLGVBQWU7WUFDZixXQUFXO1lBQ1gsZUFBZTtZQUNmLCtCQUErQjtTQUNsQzs0RkFHUSw0QkFBNEI7a0JBWnhDLFFBQVE7bUJBQUM7b0JBQ04sWUFBWSxFQUFFLENBQUUsK0JBQStCLENBQUM7b0JBQ2hELE9BQU8sRUFBRTt3QkFDTCxZQUFZO3dCQUNaLHVCQUF1Qjt3QkFDdkIsZUFBZTt3QkFDZixXQUFXO3dCQUNYLGVBQWU7d0JBQ2YsK0JBQStCO3FCQUNsQztvQkFDRCxPQUFPLEVBQUUsQ0FBRSwrQkFBK0IsQ0FBQztpQkFDOUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IE5neE1hdEVudGl0eUVkaXREaWFsb2dDb21wb25lbnQgfSBmcm9tICcuL2VkaXQtZW50aXR5LWRpYWxvZy5jb21wb25lbnQnO1xuaW1wb3J0IHsgTmd4TWF0RW50aXR5SW5wdXRNb2R1bGUgfSBmcm9tICcuLi8uLi9pbnB1dC9pbnB1dC5tb2R1bGUnO1xuaW1wb3J0IHsgTWF0RGlhbG9nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvZGlhbG9nJztcbmltcG9ydCB7IEZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgTWF0QnV0dG9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvYnV0dG9uJztcbmltcG9ydCB7IE5neE1hdEVudGl0eUNvbmZpcm1EaWFsb2dNb2R1bGUgfSBmcm9tICcuLi8uLi9jb25maXJtLWRpYWxvZy9jb25maXJtLWRpYWxvZy5tb2R1bGUnO1xuXG5ATmdNb2R1bGUoe1xuICAgIGRlY2xhcmF0aW9uczogWyBOZ3hNYXRFbnRpdHlFZGl0RGlhbG9nQ29tcG9uZW50XSxcbiAgICBpbXBvcnRzOiBbXG4gICAgICAgIENvbW1vbk1vZHVsZSxcbiAgICAgICAgTmd4TWF0RW50aXR5SW5wdXRNb2R1bGUsXG4gICAgICAgIE1hdERpYWxvZ01vZHVsZSxcbiAgICAgICAgRm9ybXNNb2R1bGUsXG4gICAgICAgIE1hdEJ1dHRvbk1vZHVsZSxcbiAgICAgICAgTmd4TWF0RW50aXR5Q29uZmlybURpYWxvZ01vZHVsZVxuICAgIF0sXG4gICAgZXhwb3J0czogWyBOZ3hNYXRFbnRpdHlFZGl0RGlhbG9nQ29tcG9uZW50XVxufSlcbmV4cG9ydCBjbGFzcyBOZ3hNYXRFbnRpdHlFZGl0RGlhbG9nTW9kdWxlIHt9Il19
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-data.js","sourceRoot":"","sources":["../../../../../projects/ngx-material-entity/src/components/table/table-data.ts"],"names":[],"mappings":"","sourcesContent":["import { HttpClient } from '@angular/common/http'\nimport { Entity } from '../../classes/entity-model.class'\nimport { EntityService } from '../../classes/entity-service.class'\nimport { ConfirmDialogData } from '../confirm-dialog/confirm-dialog-data'\n\n/**\n * The Definition of a Column inside the table.\n */\nexport interface DisplayColumn<EntityType extends Entity> {\n    /**\n     * The name inside the header.\n     */\n    displayName: string,\n    /**\n     * A method to get the value inside an row\n     */\n    value: (entity: EntityType) => string\n}\n\n/**\n * The Definition of an Action that can be run on multiple selected entities\n */\nexport interface MultiSelectAction<EntityType extends Entity> {\n    /**\n     * The name of the action\n     */\n    displayName: string,\n    /**\n     * The action itself\n     */\n    action: (selectedEntities: EntityType[]) => unknown,\n    /**\n     * A method that defines whether or not the action can be used.\n     * @default true\n     */\n    enabled?: (selectedEntities: EntityType[]) => boolean,\n    /**\n     * A method that defines whether or not a confirm dialog is needed to run the action\n     * @default false\n     */\n    requireConfirmDialog?: (selectedEntities: EntityType[]) => boolean,\n    /**\n     * The data used to generate a confirmation dialog for the multiselect action.\n     */\n    confirmDialogData?: ConfirmDialogData\n}\n\nexport interface BaseData<EntityType extends Entity> {\n    /**\n     * The title of the table\n     */\n    title: string,\n    /**\n     * The definition of the columns to display. Consists of the displayName to show in the header of the row\n     * and the value, which is a function that generates the value to display inside a column\n     */\n    displayColumns: DisplayColumn<EntityType>[],\n    /**\n     * The label on the search bar. Defaults to \"Search\".\n     */\n    searchLabel?: string,\n    /**\n     * The label on the button for adding new entities. Defaults to \"Create\".\n     */\n    createButtonLabel?: string,\n    /**\n     * The Class of the entities to manage\n     */\n    EntityClass: new (entity?: EntityType) => EntityType,\n    /**\n     * The Class of the service that handles the entities.\n     * Needs to be injectable and an extension of the \"EntityService\"-Class\n     */\n    EntityServiceClass: new (httpClient: HttpClient) => EntityService<EntityType>,\n    /**\n     * Takes a custom edit method which runs when you click on a entity.\n     * If you don't need any special editing of entries you can also omit this.\n     * In that case a default edit dialog is generated.\n     */\n    edit?: (entity: EntityType) => unknown,\n    /**\n     * Takes a method to run when you click on the new button.\n     * If you don't need anything special you can also omit this.\n     * In that case a default create dialog is generated.\n     */\n    create?: (entity: EntityType) => unknown,\n    /**\n     * Defines how the search string of entities is generated.\n     */\n    searchString?: (enity: EntityType) => string,\n    /**\n     * Defines whether or not the user can add new entities.\n     * @default true\n     */\n    allowCreate?: boolean,\n    /**\n     * Defines whether or not the user can edit entities.\n     * @default () => true\n     */\n    allowEdit?: (entity: EntityType) => boolean,\n    /**\n     * Whether or not the user can delete this specific entity\n     */\n    allowDelete?: (entity: EntityType) => boolean,\n    /**\n     * All Actions that you want to run on multiple entities can be defined here.\n     * (e.g. download as zip-file or mass delete)\n     */\n    multiSelectActions?: MultiSelectAction<EntityType>[],\n    /**\n     * The Label for the button that opens all multi-actions.\n     */\n    multiSelectLabel?: string\n}\n\nexport interface CreateDialogData {\n    /**\n     * The title of the default create-dialog.\n     */\n    title: string,\n    /**\n     * The label on the create-button of the default create-dialog. Defaults to \"Create\".\n     */\n    createButtonLabel?: string,\n    /**\n     * The label on the cancel-button for the default create-dialog. Defaults to \"Cancel\".\n     */\n    cancelButtonLabel?: string,\n    /**\n     * Whether or not the creation of an entry should require a confirm dialog.\n     */\n    createRequiresConfirmDialog?: boolean,\n    /**\n     * The data used to generate a confirmation dialog for the create action.\n     */\n    confirmCreateDialogData?: ConfirmDialogData\n}\n\nexport interface EditDialogData<EntityType extends Entity> {\n    /**\n     * The title of the default edit-dialog.\n     */\n    title: (entity: EntityType) => string,\n    /**\n     * The label on the confirm-button of the default edit-dialog. Defaults to \"Save\".\n     */\n    confirmButtonLabel?: string,\n    /**\n     * The label on the delete-button of the default edit-dialog. Defaults to \"Delete\".\n     */\n    deleteButtonLabel?: string,\n    /**\n     * The label on the cancel-button for the default edit-dialog. Defaults to \"Cancel\".\n     */\n    cancelButtonLabel?: string,\n    /**\n     * Whether or not the deletion of an entry should require a confirm dialog.\n     */\n    deleteRequiresConfirmDialog?: boolean,\n    /**\n     * Whether or not the editing of an entry should require a confirm dialog.\n     */\n    editRequiresConfirmDialog?: boolean,\n\n    /**\n     * The data used to generate a confirmation dialog for the delete action.\n     */\n    confirmDeleteDialogData?: ConfirmDialogData,\n\n    /**\n     * The data used to generate a confirmation dialog for the delete action.\n     */\n    confirmEditDialogData?: ConfirmDialogData\n}\n\nexport interface EntitiesData<EntityType extends Entity> {\n    /**\n     * The base data for the entities-component.\n     * Includes stuff like the title for the table, what to display inside the rows etc.\n     */\n    baseData: BaseData<EntityType>,\n    /**\n     * The data for the default create-dialog.\n     * Can be omitted when specifying a custom \"create\" method inside the baseData.\n     */\n    createDialogData?: CreateDialogData,\n    /**\n     * The data for the default edit-dialog.\n     * Can be omitted when specifying a custom \"edit\" method inside the baseData.\n     */\n    editDialogData?: EditDialogData<EntityType>\n}"]}
|