ngx-material-entity 16.0.4 → 16.0.6
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/README.md +4 -4
- package/classes/base.builder.d.ts +0 -4
- package/classes/entity.model.d.ts +7 -0
- package/components/confirm-dialog/confirm-dialog-data.d.ts +0 -3
- package/components/confirm-dialog/confirm-dialog.component.d.ts +6 -0
- package/components/create-page/create-data.route.d.ts +16 -0
- package/components/create-page/create-page.component.d.ts +147 -0
- package/components/create-page/page-create-data.builder.d.ts +18 -0
- package/components/edit-page/edit-data.route.d.ts +3 -0
- package/components/edit-page/edit-page.component.d.ts +34 -9
- package/components/input/array/array-string-autocomplete-chips/array-string-autocomplete-chips.component.d.ts +3 -3
- package/components/input/array/array-string-chips-input/array-string-chips-input.component.d.ts +0 -2
- package/components/input/array/array-table.class.d.ts +0 -1
- package/components/input/base-input.component.d.ts +5 -2
- package/components/input/boolean/boolean-checkbox-input/boolean-checkbox-input.component.d.ts +0 -1
- package/components/input/boolean/boolean-toggle-input/boolean-toggle-input.component.d.ts +0 -1
- package/components/input/date/date-range-input/date-range-input.component.d.ts +2 -6
- package/components/input/date/date-time-input/date-time-input.component.d.ts +0 -1
- package/components/input/file/file-input/file-input.component.d.ts +1 -0
- package/components/input/input.component.d.ts +160 -38
- package/components/input/input.module.d.ts +48 -47
- package/components/input/number/number-input/number-input.component.d.ts +1 -1
- package/components/input/relations/references-many-input/references-many-input.component.d.ts +0 -1
- package/components/input/string/string-autocomplete-input/string-autocomplete-input.component.d.ts +0 -1
- package/components/input/string/string-input/string-input.component.d.ts +1 -1
- package/components/input/string/string-textbox-input/string-textbox-input.component.d.ts +1 -1
- package/components/table/create-dialog/{create-dialog-data.builder.d.ts → create-data.builder.d.ts} +7 -7
- package/components/table/create-dialog/create-entity-dialog-data.builder.d.ts +11 -13
- package/components/table/create-dialog/create-entity-dialog-data.d.ts +7 -9
- package/components/table/create-dialog/create-entity-dialog.component.d.ts +26 -5
- package/components/table/default.actions.d.ts +0 -4
- package/components/table/display-column-value/base-display-column-value.component.d.ts +3 -0
- package/components/table/display-column-value/display-column-value.component.d.ts +9 -0
- package/components/table/edit-dialog/edit-data.builder.d.ts +3 -3
- package/components/table/edit-dialog/edit-entity-data.d.ts +2 -4
- package/components/table/edit-dialog/edit-entity-dialog.component.d.ts +34 -4
- package/components/table/edit-dialog/edit-entity.builder.d.ts +3 -5
- package/components/table/table-data.builder.d.ts +6 -8
- package/components/table/table-data.d.ts +8 -18
- package/components/table/table.component.d.ts +35 -9
- package/components/tooltip/tooltip.component.d.ts +3 -0
- package/decorators/array/array-decorator-internal.data.d.ts +3 -2
- package/decorators/array/array-decorator.data.d.ts +6 -17
- package/decorators/array/array.decorator.d.ts +0 -1
- package/decorators/base/base-property.decorator.d.ts +0 -1
- package/decorators/base/property-decorator-internal.data.d.ts +0 -2
- package/decorators/base/property-decorator.data.d.ts +0 -10
- package/decorators/boolean/boolean-decorator.data.d.ts +0 -2
- package/decorators/boolean/boolean.decorator.d.ts +0 -1
- package/decorators/custom/custom-decorator.data.d.ts +0 -2
- package/decorators/custom/custom.decorator.d.ts +0 -1
- package/decorators/date/date-decorator.data.d.ts +0 -3
- package/decorators/date/date.decorator.d.ts +0 -1
- package/decorators/file/file-decorator.data.d.ts +0 -6
- package/decorators/file/file.decorator.d.ts +0 -1
- package/decorators/has-many/has-many-decorator-internal.data.d.ts +2 -4
- package/decorators/has-many/has-many-decorator.data.d.ts +2 -6
- package/decorators/has-many/has-many.decorator.d.ts +0 -1
- package/decorators/number/number-decorator-internal.data.d.ts +0 -1
- package/decorators/number/number.decorator.d.ts +0 -1
- package/decorators/object/object.decorator.d.ts +0 -1
- package/decorators/references-many/references-many-decorator-internal.data.d.ts +0 -1
- package/decorators/references-many/references-many-decorator.data.d.ts +0 -5
- package/decorators/references-many/references-many.decorator.d.ts +0 -1
- package/decorators/references-one/references-one.decorator.d.ts +0 -1
- package/decorators/string/string-decorator-internal.data.d.ts +1 -0
- package/decorators/string/string-decorator.data.d.ts +4 -2
- package/decorators/string/string.decorator.d.ts +0 -1
- package/default-global-configuration-values.d.ts +12 -0
- package/directives/drag-drop.directive.d.ts +0 -3
- package/directives/included-in.directive.d.ts +14 -0
- package/directives/number.directive.d.ts +0 -1
- package/encapsulation/js-2-xml.utilities.d.ts +0 -1
- package/encapsulation/jszip.utilities.d.ts +0 -1
- package/encapsulation/lodash.utilities.d.ts +2 -11
- package/encapsulation/reflect.utilities.d.ts +0 -7
- package/encapsulation/uuid.utilities.d.ts +0 -1
- package/esm2022/classes/base.builder.mjs +3 -6
- package/esm2022/classes/entity.model.mjs +1 -1
- package/esm2022/components/confirm-dialog/confirm-dialog-data.builder.mjs +1 -3
- package/esm2022/components/confirm-dialog/confirm-dialog-data.mjs +1 -1
- package/esm2022/components/confirm-dialog/confirm-dialog.component.mjs +9 -3
- package/esm2022/components/create-page/create-data.route.mjs +11 -0
- package/esm2022/components/create-page/create-page.component.mjs +275 -0
- package/esm2022/components/create-page/page-create-data.builder.mjs +30 -0
- package/esm2022/components/edit-page/edit-data.route.mjs +4 -1
- package/esm2022/components/edit-page/edit-page.component.mjs +43 -18
- package/esm2022/components/edit-page/page-edit-data.builder.mjs +3 -3
- package/esm2022/components/input/array/array-date-input/array-date-input.component.mjs +11 -10
- package/esm2022/components/input/array/array-date-range-input/array-date-range-input.component.mjs +10 -9
- package/esm2022/components/input/array/array-date-time-input/array-date-time-input.component.mjs +13 -12
- package/esm2022/components/input/array/array-string-autocomplete-chips/array-string-autocomplete-chips.component.mjs +17 -13
- package/esm2022/components/input/array/array-string-chips-input/array-string-chips-input.component.mjs +8 -9
- package/esm2022/components/input/array/array-table.class.mjs +4 -6
- package/esm2022/components/input/base-input.component.mjs +8 -4
- package/esm2022/components/input/boolean/boolean-checkbox-input/boolean-checkbox-input.component.mjs +8 -11
- package/esm2022/components/input/boolean/boolean-dropdown-input/boolean-dropdown-input.component.mjs +8 -7
- package/esm2022/components/input/boolean/boolean-toggle-input/boolean-toggle-input.component.mjs +6 -9
- package/esm2022/components/input/custom/custom.component.mjs +2 -1
- package/esm2022/components/input/date/date-input/date-input.component.mjs +8 -7
- package/esm2022/components/input/date/date-range-input/date-range-input.component.mjs +38 -43
- package/esm2022/components/input/date/date-time-input/date-time-input.component.mjs +10 -10
- package/esm2022/components/input/file/file-default-input/file-default-input.component.mjs +4 -3
- package/esm2022/components/input/file/file-image-input/file-image-input.component.mjs +6 -5
- package/esm2022/components/input/file/file-input/file-input.component.mjs +9 -6
- package/esm2022/components/input/input.component.mjs +225 -91
- package/esm2022/components/input/input.module.mjs +84 -81
- package/esm2022/components/input/number/number-dropdown-input/number-dropdown-input.component.mjs +8 -7
- package/esm2022/components/input/number/number-input/number-input.component.mjs +6 -5
- package/esm2022/components/input/number/number-slider-input/number-slider-input.component.mjs +6 -5
- package/esm2022/components/input/relations/references-many-input/references-many-input.component.mjs +24 -19
- package/esm2022/components/input/string/string-autocomplete-input/string-autocomplete-input.component.mjs +12 -8
- package/esm2022/components/input/string/string-dropdown-input/string-dropdown-input.component.mjs +8 -7
- package/esm2022/components/input/string/string-input/string-input.component.mjs +6 -5
- package/esm2022/components/input/string/string-password-input/string-password-input.component.mjs +8 -7
- package/esm2022/components/input/string/string-textbox-input/string-textbox-input.component.mjs +7 -6
- package/esm2022/components/table/create-dialog/create-data.builder.mjs +44 -0
- package/esm2022/components/table/create-dialog/create-entity-dialog-data.builder.mjs +8 -9
- package/esm2022/components/table/create-dialog/create-entity-dialog-data.mjs +1 -1
- package/esm2022/components/table/create-dialog/create-entity-dialog.component.mjs +30 -9
- package/esm2022/components/table/default.actions.mjs +1 -5
- package/esm2022/components/table/display-column-value/base-display-column-value.component.mjs +5 -1
- package/esm2022/components/table/display-column-value/display-column-value.component.mjs +10 -2
- package/esm2022/components/table/edit-dialog/edit-data.builder.mjs +3 -3
- package/esm2022/components/table/edit-dialog/edit-entity-data.mjs +1 -1
- package/esm2022/components/table/edit-dialog/edit-entity-dialog.component.mjs +37 -7
- package/esm2022/components/table/edit-dialog/edit-entity.builder.mjs +3 -3
- package/esm2022/components/table/table-data.builder.mjs +12 -12
- package/esm2022/components/table/table-data.mjs +1 -1
- package/esm2022/components/table/table.component.mjs +63 -34
- package/esm2022/components/tooltip/tooltip.component.mjs +6 -3
- package/esm2022/decorators/array/array-decorator-internal.data.mjs +4 -2
- package/esm2022/decorators/array/array-decorator.data.mjs +1 -2
- package/esm2022/decorators/array/array.decorator.mjs +2 -3
- package/esm2022/decorators/base/base-property.decorator.mjs +1 -2
- package/esm2022/decorators/base/decorator-types.enum.mjs +1 -1
- package/esm2022/decorators/base/property-decorator-internal.data.mjs +1 -3
- package/esm2022/decorators/base/property-decorator.data.mjs +5 -11
- package/esm2022/decorators/boolean/boolean-decorator.data.mjs +1 -1
- package/esm2022/decorators/boolean/boolean.decorator.mjs +1 -2
- package/esm2022/decorators/custom/custom-decorator-internal.data.mjs +1 -2
- package/esm2022/decorators/custom/custom-decorator.data.mjs +1 -1
- package/esm2022/decorators/custom/custom.decorator.mjs +1 -2
- package/esm2022/decorators/date/date-decorator-internal.data.mjs +2 -2
- package/esm2022/decorators/date/date-decorator.data.mjs +1 -1
- package/esm2022/decorators/date/date.decorator.mjs +2 -3
- package/esm2022/decorators/file/file-decorator-internal.data.mjs +1 -4
- package/esm2022/decorators/file/file-decorator.data.mjs +1 -6
- package/esm2022/decorators/file/file.decorator.mjs +2 -3
- package/esm2022/decorators/has-many/has-many-decorator-internal.data.mjs +1 -2
- package/esm2022/decorators/has-many/has-many-decorator.data.mjs +1 -1
- package/esm2022/decorators/has-many/has-many.decorator.mjs +1 -2
- package/esm2022/decorators/number/number-decorator-internal.data.mjs +4 -5
- package/esm2022/decorators/number/number-decorator.data.mjs +1 -1
- package/esm2022/decorators/number/number.decorator.mjs +1 -2
- package/esm2022/decorators/object/object.decorator.mjs +1 -2
- package/esm2022/decorators/references-many/references-many-decorator-internal.data.mjs +1 -2
- package/esm2022/decorators/references-many/references-many-decorator.data.mjs +1 -1
- package/esm2022/decorators/references-many/references-many.decorator.mjs +1 -2
- package/esm2022/decorators/references-one/references-one.decorator.mjs +1 -2
- package/esm2022/decorators/string/string-decorator-internal.data.mjs +7 -4
- package/esm2022/decorators/string/string-decorator.data.mjs +1 -1
- package/esm2022/decorators/string/string.decorator.mjs +1 -2
- package/esm2022/default-global-configuration-values.mjs +16 -1
- package/esm2022/directives/drag-drop.directive.mjs +1 -4
- package/esm2022/directives/included-in.directive.mjs +33 -0
- package/esm2022/directives/number.directive.mjs +1 -2
- package/esm2022/directives/password-match.directive.mjs +2 -2
- package/esm2022/encapsulation/js-2-xml.utilities.mjs +1 -2
- package/esm2022/encapsulation/jszip.utilities.mjs +1 -2
- package/esm2022/encapsulation/lodash.utilities.mjs +12 -19
- package/esm2022/encapsulation/reflect.utilities.mjs +1 -8
- package/esm2022/encapsulation/uuid.utilities.mjs +1 -2
- package/esm2022/functions/default-false.function.mjs +1 -2
- package/esm2022/functions/default-true.function.mjs +1 -2
- package/esm2022/functions/get-config-value.function.mjs +1 -2
- package/esm2022/functions/get-validation-error-message.function.mjs +13 -7
- package/esm2022/functions/get-validation-errors-tooltip-content.function.ts.mjs +6 -4
- package/esm2022/functions/is-async-function.function.mjs +1 -2
- package/esm2022/global-configuration-values.mjs +5 -2
- package/esm2022/mocks/placeholder-data.png.mjs +3 -3
- package/esm2022/public-api.mjs +3 -1
- package/esm2022/services/entity.service.mjs +15 -21
- package/esm2022/services/unsaved-changes.guard.mjs +7 -2
- package/esm2022/utilities/date.utilities.mjs +3 -9
- package/esm2022/utilities/entity.utilities.mjs +82 -79
- package/esm2022/utilities/file.utilities.mjs +1 -10
- package/esm2022/utilities/selection.utilities.mjs +4 -7
- package/esm2022/utilities/validation.utilities.mjs +40 -35
- package/fesm2022/ngx-material-entity.mjs +1309 -752
- package/fesm2022/ngx-material-entity.mjs.map +1 -1
- package/functions/default-false.function.d.ts +0 -1
- package/functions/default-true.function.d.ts +0 -1
- package/functions/get-config-value.function.d.ts +0 -1
- package/functions/get-validation-error-message.function.d.ts +3 -0
- package/functions/get-validation-errors-tooltip-content.function.ts.d.ts +4 -2
- package/functions/is-async-function.function.d.ts +0 -1
- package/global-configuration-values.d.ts +9 -34
- package/mocks/placeholder-data.png.d.ts +1 -1
- package/package.json +2 -1
- package/public-api.d.ts +2 -0
- package/services/entity.service.d.ts +11 -16
- package/services/unsaved-changes.guard.d.ts +13 -1
- package/utilities/date.utilities.d.ts +0 -6
- package/utilities/entity.utilities.d.ts +10 -36
- package/utilities/file.utilities.d.ts +0 -9
- package/utilities/selection.utilities.d.ts +0 -3
- package/utilities/validation.utilities.d.ts +0 -3
- package/esm2022/components/table/create-dialog/create-dialog-data.builder.mjs +0 -44
|
@@ -0,0 +1,275 @@
|
|
|
1
|
+
import { Location, NgFor, NgIf } from '@angular/common';
|
|
2
|
+
import { HttpClient } from '@angular/common/http';
|
|
3
|
+
import { Component, ElementRef, EnvironmentInjector, HostListener, Inject, InjectionToken, Renderer2, runInInjectionContext } from '@angular/core';
|
|
4
|
+
import { MatBadgeModule } from '@angular/material/badge';
|
|
5
|
+
import { MatButtonModule } from '@angular/material/button';
|
|
6
|
+
import { MatDialog } from '@angular/material/dialog';
|
|
7
|
+
import { MatProgressSpinnerModule } from '@angular/material/progress-spinner';
|
|
8
|
+
import { MatTabsModule } from '@angular/material/tabs';
|
|
9
|
+
import { first, map } from 'rxjs';
|
|
10
|
+
import { NGX_INTERNAL_GLOBAL_DEFAULT_VALUES } from '../../default-global-configuration-values';
|
|
11
|
+
import { LodashUtilities } from '../../encapsulation/lodash.utilities';
|
|
12
|
+
import { getValidationErrorsTooltipContent } from '../../functions/get-validation-errors-tooltip-content.function.ts';
|
|
13
|
+
import { EntityService } from '../../services/entity.service';
|
|
14
|
+
import { EntityUtilities } from '../../utilities/entity.utilities';
|
|
15
|
+
import { ValidationUtilities } from '../../utilities/validation.utilities';
|
|
16
|
+
import { ConfirmDialogDataBuilder } from '../confirm-dialog/confirm-dialog-data.builder';
|
|
17
|
+
import { NgxMatEntityConfirmDialogComponent } from '../confirm-dialog/confirm-dialog.component';
|
|
18
|
+
import { NgxMatEntityInputModule } from '../input/input.module';
|
|
19
|
+
import { TooltipComponent } from '../tooltip/tooltip.component';
|
|
20
|
+
import { PageCreateDataBuilder } from './page-create-data.builder';
|
|
21
|
+
import * as i0 from "@angular/core";
|
|
22
|
+
import * as i1 from "@angular/material/dialog";
|
|
23
|
+
import * as i2 from "@angular/common";
|
|
24
|
+
import * as i3 from "@angular/common/http";
|
|
25
|
+
import * as i4 from "@angular/material/button";
|
|
26
|
+
import * as i5 from "@angular/material/tabs";
|
|
27
|
+
import * as i6 from "../input/input.component";
|
|
28
|
+
import * as i7 from "@angular/material/progress-spinner";
|
|
29
|
+
import * as i8 from "@angular/material/badge";
|
|
30
|
+
import * as i9 from "../../services/entity.service";
|
|
31
|
+
/**
|
|
32
|
+
* The entity service that needs to be provided in the providers array of the create page route.
|
|
33
|
+
*/
|
|
34
|
+
// eslint-disable-next-line max-len, typescript/no-explicit-any, constCase/uppercase
|
|
35
|
+
export const NGX_CREATE_DATA_ENTITY_SERVICE = new InjectionToken('NGX_CREATE_DATA_ENTITY_SERVICE');
|
|
36
|
+
/**
|
|
37
|
+
* The entity class that needs to be provided in the providers array of the create page route.
|
|
38
|
+
*/
|
|
39
|
+
// eslint-disable-next-line max-len, typescript/no-explicit-any, constCase/uppercase
|
|
40
|
+
export const NGX_CREATE_DATA_ENTITY = new InjectionToken('NGX_CREATE_DATA_ENTITY');
|
|
41
|
+
/**
|
|
42
|
+
* The configuration that needs to be provided in the providers array of the create page route.
|
|
43
|
+
*/
|
|
44
|
+
// eslint-disable-next-line typescript/no-explicit-any, constCase/uppercase
|
|
45
|
+
export const NGX_CREATE_DATA = new InjectionToken('NGX_CREATE_DATA');
|
|
46
|
+
/**
|
|
47
|
+
* A generic page that allows you to create a specific entity.
|
|
48
|
+
* For this to work you need to provide some data for the route.
|
|
49
|
+
*/
|
|
50
|
+
export class NgxMatEntityCreatePageComponent {
|
|
51
|
+
dialog;
|
|
52
|
+
location;
|
|
53
|
+
injector;
|
|
54
|
+
entityService;
|
|
55
|
+
EntityClass;
|
|
56
|
+
inputData;
|
|
57
|
+
http;
|
|
58
|
+
el;
|
|
59
|
+
renderer;
|
|
60
|
+
globalConfig;
|
|
61
|
+
/**
|
|
62
|
+
* Contains HelperMethods around handling Entities and their property-metadata.
|
|
63
|
+
*/
|
|
64
|
+
EntityUtilities = EntityUtilities;
|
|
65
|
+
/**
|
|
66
|
+
* The tabs to display.
|
|
67
|
+
*/
|
|
68
|
+
entityTabs;
|
|
69
|
+
/**
|
|
70
|
+
* The entity to create.
|
|
71
|
+
*/
|
|
72
|
+
entity;
|
|
73
|
+
/**
|
|
74
|
+
* The entity before any changes have been made.
|
|
75
|
+
* This is used to determine if leaving the page is possible without interruption.
|
|
76
|
+
*/
|
|
77
|
+
entityPriorChanges;
|
|
78
|
+
/**
|
|
79
|
+
* Configuration data for this component.
|
|
80
|
+
*/
|
|
81
|
+
data;
|
|
82
|
+
/**
|
|
83
|
+
* All validation errors of the entity.
|
|
84
|
+
*/
|
|
85
|
+
validationErrors;
|
|
86
|
+
/**
|
|
87
|
+
* Whether or not the entity is valid.
|
|
88
|
+
*/
|
|
89
|
+
isEntityValid = false;
|
|
90
|
+
/**
|
|
91
|
+
* Whether or not the entity is dirty.
|
|
92
|
+
*/
|
|
93
|
+
isEntityDirty = false;
|
|
94
|
+
/**
|
|
95
|
+
* What to display inside the tooltip.
|
|
96
|
+
*/
|
|
97
|
+
tooltipContent = '';
|
|
98
|
+
inConfirmNavigation = false;
|
|
99
|
+
// eslint-disable-next-line jsdoc/require-jsdoc
|
|
100
|
+
get hasUnsavedChanges() {
|
|
101
|
+
return this.isEntityDirty && this.data.createData.unsavedChangesRequireConfirmDialog;
|
|
102
|
+
}
|
|
103
|
+
constructor(dialog, location, injector, entityService, EntityClass, inputData, http, el, renderer, globalConfig) {
|
|
104
|
+
this.dialog = dialog;
|
|
105
|
+
this.location = location;
|
|
106
|
+
this.injector = injector;
|
|
107
|
+
this.entityService = entityService;
|
|
108
|
+
this.EntityClass = EntityClass;
|
|
109
|
+
this.inputData = inputData;
|
|
110
|
+
this.http = http;
|
|
111
|
+
this.el = el;
|
|
112
|
+
this.renderer = renderer;
|
|
113
|
+
this.globalConfig = globalConfig;
|
|
114
|
+
}
|
|
115
|
+
ngOnInit() {
|
|
116
|
+
this.data = new PageCreateDataBuilder(this.inputData, this.globalConfig).getResult();
|
|
117
|
+
if (this.data == null) {
|
|
118
|
+
this.confirmNavigateBack();
|
|
119
|
+
// eslint-disable-next-line max-len
|
|
120
|
+
throw new Error('No create data was provided for "NGX_CREATE_DATA". You need to provide a value in your routes providers array.');
|
|
121
|
+
}
|
|
122
|
+
this.entity = new this.EntityClass();
|
|
123
|
+
EntityUtilities.setDefaultValues(this.entity);
|
|
124
|
+
this.entityPriorChanges = LodashUtilities.cloneDeep(this.entity);
|
|
125
|
+
this.checkIsEntityValid();
|
|
126
|
+
this.entityTabs = EntityUtilities.getEntityTabs(this.entity, this.injector, true, false);
|
|
127
|
+
setTimeout(() => this.checkOffset(), 1);
|
|
128
|
+
// setTimeout(() => this.checkEntity(), 1);
|
|
129
|
+
}
|
|
130
|
+
/**
|
|
131
|
+
* Whether the page can be left without confirmation (of unsaved changes).
|
|
132
|
+
* @returns Whether or not the page can be left without confirmation.
|
|
133
|
+
*/
|
|
134
|
+
canDeactivate() {
|
|
135
|
+
return !this.hasUnsavedChanges || this.inConfirmNavigation;
|
|
136
|
+
}
|
|
137
|
+
/**
|
|
138
|
+
* Checks if the bottom row should be displayed as fixed.
|
|
139
|
+
*/
|
|
140
|
+
checkOffset() {
|
|
141
|
+
const scrollY = window.scrollY;
|
|
142
|
+
const bottomRow = this.el.nativeElement.querySelector('.bottom-row');
|
|
143
|
+
const bottomRowContainer = this.el.nativeElement.querySelector('.bottom-row-container');
|
|
144
|
+
if (bottomRow && bottomRowContainer) {
|
|
145
|
+
const bottomRowContainerOffset = bottomRowContainer.offsetTop;
|
|
146
|
+
const windowHeight = window.innerHeight;
|
|
147
|
+
if (scrollY + windowHeight >= bottomRowContainerOffset) {
|
|
148
|
+
this.renderer.removeClass(bottomRow, 'fixed');
|
|
149
|
+
}
|
|
150
|
+
else {
|
|
151
|
+
this.renderer.addClass(bottomRow, 'fixed');
|
|
152
|
+
}
|
|
153
|
+
}
|
|
154
|
+
}
|
|
155
|
+
/**
|
|
156
|
+
* Checks if the entity has become invalid or dirty.
|
|
157
|
+
*/
|
|
158
|
+
async checkEntity() {
|
|
159
|
+
this.checkIsEntityValid();
|
|
160
|
+
this.isEntityDirty = await EntityUtilities.isDirty(this.entity, this.entityPriorChanges, this.http);
|
|
161
|
+
}
|
|
162
|
+
checkIsEntityValid() {
|
|
163
|
+
this.validationErrors = ValidationUtilities.getEntityValidationErrors(this.entity, 'create');
|
|
164
|
+
this.tooltipContent = runInInjectionContext(this.injector, () => getValidationErrorsTooltipContent(this.validationErrors));
|
|
165
|
+
this.isEntityValid = this.validationErrors.length === 0;
|
|
166
|
+
}
|
|
167
|
+
/**
|
|
168
|
+
* Tries create the entity and navigate back afterwards.
|
|
169
|
+
* Also handles the confirmation if required.
|
|
170
|
+
*/
|
|
171
|
+
create() {
|
|
172
|
+
if (!this.isEntityValid) {
|
|
173
|
+
return;
|
|
174
|
+
}
|
|
175
|
+
if (!this.data.createData.createRequiresConfirmDialog) {
|
|
176
|
+
this.confirmCreate();
|
|
177
|
+
return;
|
|
178
|
+
}
|
|
179
|
+
// eslint-disable-next-line max-len
|
|
180
|
+
const dialogData = new ConfirmDialogDataBuilder(this.globalConfig, this.data.createData.confirmCreateDialogData)
|
|
181
|
+
.withDefault('text', this.globalConfig.confirmCreateText)
|
|
182
|
+
.withDefault('confirmButtonLabel', this.globalConfig.createLabel)
|
|
183
|
+
.withDefault('title', this.globalConfig.createLabel)
|
|
184
|
+
.getResult();
|
|
185
|
+
const dialogRef = this.dialog.open(NgxMatEntityConfirmDialogComponent, {
|
|
186
|
+
data: dialogData,
|
|
187
|
+
autoFocus: false,
|
|
188
|
+
restoreFocus: false
|
|
189
|
+
});
|
|
190
|
+
dialogRef.afterClosed().subscribe(res => {
|
|
191
|
+
if (res == true) {
|
|
192
|
+
this.confirmCreate();
|
|
193
|
+
}
|
|
194
|
+
});
|
|
195
|
+
}
|
|
196
|
+
confirmCreate() {
|
|
197
|
+
void this.entityService.create(this.entity).then(() => this.confirmNavigateBack());
|
|
198
|
+
}
|
|
199
|
+
/**
|
|
200
|
+
* Tries to navigate back.
|
|
201
|
+
*/
|
|
202
|
+
navigateBack() {
|
|
203
|
+
if (!this.hasUnsavedChanges) {
|
|
204
|
+
this.confirmNavigateBack();
|
|
205
|
+
return;
|
|
206
|
+
}
|
|
207
|
+
this.openConfirmNavigationDialog().subscribe(res => {
|
|
208
|
+
if (res) {
|
|
209
|
+
this.confirmNavigateBack();
|
|
210
|
+
}
|
|
211
|
+
});
|
|
212
|
+
}
|
|
213
|
+
/**
|
|
214
|
+
* Opens the confirm dialog for navigating with unsaved changes.
|
|
215
|
+
* This is exposed because the UnsavedChangesGuard needs to access this.
|
|
216
|
+
* @returns The first observable result of the confirm dialog.
|
|
217
|
+
*/
|
|
218
|
+
openConfirmNavigationDialog() {
|
|
219
|
+
const dialogRef = this.dialog.open(NgxMatEntityConfirmDialogComponent, {
|
|
220
|
+
data: this.data.createData.confirmUnsavedChangesDialogData,
|
|
221
|
+
autoFocus: false,
|
|
222
|
+
restoreFocus: false
|
|
223
|
+
});
|
|
224
|
+
return dialogRef.afterClosed().pipe(first(), map(p => (p ?? false)));
|
|
225
|
+
}
|
|
226
|
+
confirmNavigateBack() {
|
|
227
|
+
this.inConfirmNavigation = true;
|
|
228
|
+
this.location.back();
|
|
229
|
+
}
|
|
230
|
+
/**
|
|
231
|
+
* Checks if the input with the given key is readonly.
|
|
232
|
+
* @param key - The key for the input to check.
|
|
233
|
+
* @returns Whether or not the input for the key is read only.
|
|
234
|
+
*/
|
|
235
|
+
isReadOnly(key) {
|
|
236
|
+
return runInInjectionContext(this.injector, () => {
|
|
237
|
+
const metadata = EntityUtilities.getPropertyMetadata(this.entity, key);
|
|
238
|
+
return metadata.isReadOnly(this.entity);
|
|
239
|
+
});
|
|
240
|
+
}
|
|
241
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.0", ngImport: i0, type: NgxMatEntityCreatePageComponent, deps: [{ token: i1.MatDialog }, { token: i2.Location }, { token: i0.EnvironmentInjector }, { token: NGX_CREATE_DATA_ENTITY_SERVICE }, { token: NGX_CREATE_DATA_ENTITY }, { token: NGX_CREATE_DATA }, { token: i3.HttpClient }, { token: i0.ElementRef }, { token: i0.Renderer2 }, { token: NGX_INTERNAL_GLOBAL_DEFAULT_VALUES }], target: i0.ɵɵFactoryTarget.Component });
|
|
242
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.0", type: NgxMatEntityCreatePageComponent, isStandalone: true, selector: "ngx-mat-entity-create-page", host: { listeners: { "window:beforeunload": "canDeactivate()", "window:scroll": "checkOffset()" } }, ngImport: i0, template: "<!-- eslint-disable angular/no-call-expression -->\n<!-- eslint-disable angular/cyclomatic-complexity -->\n<div *ngIf=\"!entityTabs && data.displayLoadingSpinner\" class=\"container\">\n <br>\n <mat-spinner></mat-spinner>\n <br>\n</div>\n\n<div *ngIf=\"entityTabs\" class=\"container\">\n <br>\n\n <!------------>\n <!-- Header -->\n <!------------>\n <div class=\"header\">\n <div class=\"cancel-container\">\n <button type=\"button\" mat-raised-button class=\"back-button\" tabindex=\"-1\" [class.unsavedChanges]=\"hasUnsavedChanges\" (click)=\"navigateBack()\">\n <i class=\"fas fa-chevron-left\"></i>\n {{data.createData.cancelButtonLabel}}\n <i *ngIf=\"hasUnsavedChanges\" class=\"fas fa-warning\"></i>\n </button>\n </div>\n </div>\n\n <h1>{{data.createData.title}}</h1>\n\n <!----------->\n <!-- Input -->\n <!----------->\n <form>\n <mat-tab-group *ngIf=\"entityTabs.length > 1\" preserveContent (selectedTabChange)=\"checkOffset()\">\n <mat-tab *ngFor=\"let tab of entityTabs\" [label]=\"tab.tabName\">\n <div *ngFor=\"let row of tab.rows\" class=\"row\">\n <ngx-mat-entity-input\n *ngFor=\"let key of row.keys\"\n [entity]=\"entity\"\n [propertyKey]=\"key\"\n [hideOmitForEdit]=\"true\"\n [class]=\"EntityUtilities.getWidthClasses(entity, key)\"\n [isReadOnly]=\"isReadOnly(key)\"\n (inputChangeEvent)=\"checkEntity()\"\n >\n </ngx-mat-entity-input>\n </div>\n </mat-tab>\n </mat-tab-group>\n \n <div *ngIf=\"entityTabs.length <= 1\">\n <span *ngIf=\"!entityTabs.length\" class=\"no-entity-tabs\">\n ERROR: No Inputs. Did you correctly assign all values in the model constructor?\n </span>\n <div *ngFor=\"let row of entityTabs[0]?.rows\" class=\"row\">\n <ngx-mat-entity-input\n *ngFor=\"let key of row.keys\"\n [entity]=\"entity\"\n [propertyKey]=\"key\"\n [hideOmitForEdit]=\"true\"\n [class]=\"EntityUtilities.getWidthClasses(entity, key)\"\n [isReadOnly]=\"isReadOnly(key)\"\n (inputChangeEvent)=\"checkEntity()\"\n >\n </ngx-mat-entity-input>\n </div>\n </div>\n\n <div class=\"bottom-row-container\">\n <div class=\"bottom-row container\" style=\"margin-top: 10px;\">\n <button type=\"submit\" mat-raised-button matBadgeColor=\"warn\"\n [disabled]=\"!isEntityValid || !isEntityDirty\"\n [matBadge]=\"validationErrors.length\"\n [matBadgeHidden]=\"!validationErrors.length\"\n (click)=\"create()\"\n >\n {{data.createData.createButtonLabel}}\n </button>\n <ngx-mat-entity-tooltip *ngIf=\"validationErrors.length\" [tooltipContent]=\"tooltipContent\"></ngx-mat-entity-tooltip>\n </div>\n </div>\n </form>\n\n <br>\n</div>", styles: ["h1{text-align:center}mat-spinner{margin:10px auto}.fa-warning{color:orange}.bottom-row{display:flex;align-items:center;column-gap:10px}.fixed{position:fixed;bottom:0;left:0;right:0;width:100%;z-index:1000;padding:8px 20px;background-color:#fff}.no-entity-tabs{padding:10px;background-color:red;color:#f5f5f5}.header{display:flex;margin-bottom:5px;gap:10px;flex-wrap:wrap}.header button{min-width:150px}.header .cancel-container{display:flex;justify-content:flex-start;align-items:center;column-gap:10px;width:calc(50% - 10px)}.unsavedChanges{background-color:#ffe48d}@media (max-width: 800px){.header{margin-bottom:10px;gap:15px}.header button{min-width:0px;width:50%}.header .cancel-container{width:100%;gap:15px}}\n"], dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgFor, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i4.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "ngmodule", type: MatTabsModule }, { kind: "component", type: i5.MatTab, selector: "mat-tab", inputs: ["disabled"], exportAs: ["matTab"] }, { kind: "component", type: i5.MatTabGroup, selector: "mat-tab-group", inputs: ["color", "disableRipple", "fitInkBarToContent", "mat-stretch-tabs"], exportAs: ["matTabGroup"] }, { kind: "ngmodule", type: NgxMatEntityInputModule }, { kind: "component", type: i6.NgxMatEntityInputComponent, selector: "ngx-mat-entity-input", inputs: ["entity", "propertyKey", "getValidationErrorMessage", "hideOmitForCreate", "hideOmitForEdit", "validEmpty", "isReadOnly"], outputs: ["inputChangeEvent"] }, { kind: "ngmodule", type: MatProgressSpinnerModule }, { kind: "component", type: i7.MatProgressSpinner, selector: "mat-progress-spinner, mat-spinner", inputs: ["color", "mode", "value", "diameter", "strokeWidth"], exportAs: ["matProgressSpinner"] }, { kind: "ngmodule", type: MatBadgeModule }, { kind: "directive", type: i8.MatBadge, selector: "[matBadge]", inputs: ["matBadgeDisabled", "matBadgeColor", "matBadgeOverlap", "matBadgePosition", "matBadge", "matBadgeDescription", "matBadgeSize", "matBadgeHidden"] }, { kind: "component", type: TooltipComponent, selector: "ngx-mat-entity-tooltip", inputs: ["tooltipContent"] }] });
|
|
243
|
+
}
|
|
244
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.0", ngImport: i0, type: NgxMatEntityCreatePageComponent, decorators: [{
|
|
245
|
+
type: Component,
|
|
246
|
+
args: [{ selector: 'ngx-mat-entity-create-page', standalone: true, imports: [
|
|
247
|
+
NgIf,
|
|
248
|
+
NgFor,
|
|
249
|
+
MatButtonModule,
|
|
250
|
+
MatTabsModule,
|
|
251
|
+
NgxMatEntityInputModule,
|
|
252
|
+
MatProgressSpinnerModule,
|
|
253
|
+
MatBadgeModule,
|
|
254
|
+
TooltipComponent
|
|
255
|
+
], template: "<!-- eslint-disable angular/no-call-expression -->\n<!-- eslint-disable angular/cyclomatic-complexity -->\n<div *ngIf=\"!entityTabs && data.displayLoadingSpinner\" class=\"container\">\n <br>\n <mat-spinner></mat-spinner>\n <br>\n</div>\n\n<div *ngIf=\"entityTabs\" class=\"container\">\n <br>\n\n <!------------>\n <!-- Header -->\n <!------------>\n <div class=\"header\">\n <div class=\"cancel-container\">\n <button type=\"button\" mat-raised-button class=\"back-button\" tabindex=\"-1\" [class.unsavedChanges]=\"hasUnsavedChanges\" (click)=\"navigateBack()\">\n <i class=\"fas fa-chevron-left\"></i>\n {{data.createData.cancelButtonLabel}}\n <i *ngIf=\"hasUnsavedChanges\" class=\"fas fa-warning\"></i>\n </button>\n </div>\n </div>\n\n <h1>{{data.createData.title}}</h1>\n\n <!----------->\n <!-- Input -->\n <!----------->\n <form>\n <mat-tab-group *ngIf=\"entityTabs.length > 1\" preserveContent (selectedTabChange)=\"checkOffset()\">\n <mat-tab *ngFor=\"let tab of entityTabs\" [label]=\"tab.tabName\">\n <div *ngFor=\"let row of tab.rows\" class=\"row\">\n <ngx-mat-entity-input\n *ngFor=\"let key of row.keys\"\n [entity]=\"entity\"\n [propertyKey]=\"key\"\n [hideOmitForEdit]=\"true\"\n [class]=\"EntityUtilities.getWidthClasses(entity, key)\"\n [isReadOnly]=\"isReadOnly(key)\"\n (inputChangeEvent)=\"checkEntity()\"\n >\n </ngx-mat-entity-input>\n </div>\n </mat-tab>\n </mat-tab-group>\n \n <div *ngIf=\"entityTabs.length <= 1\">\n <span *ngIf=\"!entityTabs.length\" class=\"no-entity-tabs\">\n ERROR: No Inputs. Did you correctly assign all values in the model constructor?\n </span>\n <div *ngFor=\"let row of entityTabs[0]?.rows\" class=\"row\">\n <ngx-mat-entity-input\n *ngFor=\"let key of row.keys\"\n [entity]=\"entity\"\n [propertyKey]=\"key\"\n [hideOmitForEdit]=\"true\"\n [class]=\"EntityUtilities.getWidthClasses(entity, key)\"\n [isReadOnly]=\"isReadOnly(key)\"\n (inputChangeEvent)=\"checkEntity()\"\n >\n </ngx-mat-entity-input>\n </div>\n </div>\n\n <div class=\"bottom-row-container\">\n <div class=\"bottom-row container\" style=\"margin-top: 10px;\">\n <button type=\"submit\" mat-raised-button matBadgeColor=\"warn\"\n [disabled]=\"!isEntityValid || !isEntityDirty\"\n [matBadge]=\"validationErrors.length\"\n [matBadgeHidden]=\"!validationErrors.length\"\n (click)=\"create()\"\n >\n {{data.createData.createButtonLabel}}\n </button>\n <ngx-mat-entity-tooltip *ngIf=\"validationErrors.length\" [tooltipContent]=\"tooltipContent\"></ngx-mat-entity-tooltip>\n </div>\n </div>\n </form>\n\n <br>\n</div>", styles: ["h1{text-align:center}mat-spinner{margin:10px auto}.fa-warning{color:orange}.bottom-row{display:flex;align-items:center;column-gap:10px}.fixed{position:fixed;bottom:0;left:0;right:0;width:100%;z-index:1000;padding:8px 20px;background-color:#fff}.no-entity-tabs{padding:10px;background-color:red;color:#f5f5f5}.header{display:flex;margin-bottom:5px;gap:10px;flex-wrap:wrap}.header button{min-width:150px}.header .cancel-container{display:flex;justify-content:flex-start;align-items:center;column-gap:10px;width:calc(50% - 10px)}.unsavedChanges{background-color:#ffe48d}@media (max-width: 800px){.header{margin-bottom:10px;gap:15px}.header button{min-width:0px;width:50%}.header .cancel-container{width:100%;gap:15px}}\n"] }]
|
|
256
|
+
}], ctorParameters: function () { return [{ type: i1.MatDialog }, { type: i2.Location }, { type: i0.EnvironmentInjector }, { type: i9.EntityService, decorators: [{
|
|
257
|
+
type: Inject,
|
|
258
|
+
args: [NGX_CREATE_DATA_ENTITY_SERVICE]
|
|
259
|
+
}] }, { type: undefined, decorators: [{
|
|
260
|
+
type: Inject,
|
|
261
|
+
args: [NGX_CREATE_DATA_ENTITY]
|
|
262
|
+
}] }, { type: undefined, decorators: [{
|
|
263
|
+
type: Inject,
|
|
264
|
+
args: [NGX_CREATE_DATA]
|
|
265
|
+
}] }, { type: i3.HttpClient }, { type: i0.ElementRef }, { type: i0.Renderer2 }, { type: undefined, decorators: [{
|
|
266
|
+
type: Inject,
|
|
267
|
+
args: [NGX_INTERNAL_GLOBAL_DEFAULT_VALUES]
|
|
268
|
+
}] }]; }, propDecorators: { canDeactivate: [{
|
|
269
|
+
type: HostListener,
|
|
270
|
+
args: ['window:beforeunload']
|
|
271
|
+
}], checkOffset: [{
|
|
272
|
+
type: HostListener,
|
|
273
|
+
args: ['window:scroll']
|
|
274
|
+
}] } });
|
|
275
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-page.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-material-entity/src/components/create-page/create-page.component.ts","../../../../../projects/ngx-material-entity/src/components/create-page/create-page.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Location, NgFor, NgIf } from '@angular/common';\nimport { HttpClient } from '@angular/common/http';\nimport { Component, ElementRef, EnvironmentInjector, HostListener, Inject, InjectionToken, OnInit, Renderer2, runInInjectionContext } from '@angular/core';\nimport { MatBadgeModule } from '@angular/material/badge';\nimport { MatButtonModule } from '@angular/material/button';\nimport { MatDialog, MatDialogRef } from '@angular/material/dialog';\nimport { MatProgressSpinnerModule } from '@angular/material/progress-spinner';\nimport { MatTabsModule } from '@angular/material/tabs';\nimport { Observable, first, map } from 'rxjs';\nimport { BaseEntityType, EntityClassNewable } from '../../classes/entity.model';\nimport { PropertyDecoratorConfigInternal } from '../../decorators/base/property-decorator-internal.data';\nimport { NGX_INTERNAL_GLOBAL_DEFAULT_VALUES } from '../../default-global-configuration-values';\nimport { LodashUtilities } from '../../encapsulation/lodash.utilities';\nimport { getValidationErrorsTooltipContent } from '../../functions/get-validation-errors-tooltip-content.function.ts';\nimport { NgxGlobalDefaultValues } from '../../global-configuration-values';\nimport { EntityService } from '../../services/entity.service';\nimport { EntityTab, EntityUtilities } from '../../utilities/entity.utilities';\nimport { ValidationError, ValidationUtilities } from '../../utilities/validation.utilities';\nimport { ConfirmDialogData } from '../confirm-dialog/confirm-dialog-data';\nimport { ConfirmDialogDataBuilder, ConfirmDialogDataInternal } from '../confirm-dialog/confirm-dialog-data.builder';\nimport { NgxMatEntityConfirmDialogComponent } from '../confirm-dialog/confirm-dialog.component';\nimport { NgxMatEntityInputModule } from '../input/input.module';\nimport { CreateEntityData } from '../table/create-dialog/create-entity-dialog-data';\nimport { CreateData } from '../table/table-data';\nimport { TooltipComponent } from '../tooltip/tooltip.component';\nimport { PageCreateDataBuilder, PageCreateDataInternal } from './page-create-data.builder';\n\n/**\n * The data that needs to be provided for a route to be able to create a entity.\n */\n// eslint-disable-next-line max-len\nexport type PageCreateData<EntityType extends BaseEntityType<EntityType>> = Omit<CreateEntityData<EntityType>, 'entity' | 'EntityServiceClass'> & {\n    /**\n     * Whether or not to display a loading spinner while the data for the page is loaded.\n     * @default true\n     */\n    displayLoadingSpinner?: boolean,\n    /**\n     * The data of the default create page.\n     */\n    createData?: CreateData & {\n        /**\n         * The data for the dialog when the user tries to leave the site with unsaved changes.\n         */\n        confirmUnsavedChangesDialogData?: ConfirmDialogData,\n        /**\n         * Whether or not leaving with unsaved changes should require a confirm dialog.\n         * @default true\n         */\n        unsavedChangesRequireConfirmDialog?: boolean\n    }\n};\n\n/**\n * The entity service that needs to be provided in the providers array of the create page route.\n */\n// eslint-disable-next-line max-len, typescript/no-explicit-any, constCase/uppercase\nexport const NGX_CREATE_DATA_ENTITY_SERVICE: InjectionToken<EntityService<any>> = new InjectionToken<EntityService<any>>('NGX_CREATE_DATA_ENTITY_SERVICE');\n/**\n * The entity class that needs to be provided in the providers array of the create page route.\n */\n// eslint-disable-next-line max-len, typescript/no-explicit-any, constCase/uppercase\nexport const NGX_CREATE_DATA_ENTITY: InjectionToken<EntityClassNewable<any>> = new InjectionToken<EntityClassNewable<any>>('NGX_CREATE_DATA_ENTITY');\n/**\n * The configuration that needs to be provided in the providers array of the create page route.\n */\n// eslint-disable-next-line typescript/no-explicit-any, constCase/uppercase\nexport const NGX_CREATE_DATA: InjectionToken<PageCreateData<any>> = new InjectionToken<PageCreateData<any>>('NGX_CREATE_DATA');\n\n/**\n * A generic page that allows you to create a specific entity.\n * For this to work you need to provide some data for the route.\n */\n@Component({\n    selector: 'ngx-mat-entity-create-page',\n    templateUrl: './create-page.component.html',\n    styleUrls: ['./create-page.component.scss'],\n    standalone: true,\n    imports: [\n        NgIf,\n        NgFor,\n        MatButtonModule,\n        MatTabsModule,\n        NgxMatEntityInputModule,\n        MatProgressSpinnerModule,\n        MatBadgeModule,\n        TooltipComponent\n    ]\n})\nexport class NgxMatEntityCreatePageComponent<EntityType extends BaseEntityType<EntityType>> implements OnInit {\n\n    /**\n     * Contains HelperMethods around handling Entities and their property-metadata.\n     */\n    EntityUtilities: typeof EntityUtilities = EntityUtilities;\n\n    /**\n     * The tabs to display.\n     */\n    entityTabs!: EntityTab<EntityType>[];\n\n    /**\n     * The entity to create.\n     */\n    entity!: EntityType;\n    /**\n     * The entity before any changes have been made.\n     * This is used to determine if leaving the page is possible without interruption.\n     */\n    entityPriorChanges!: EntityType;\n\n    /**\n     * Configuration data for this component.\n     */\n    data!: PageCreateDataInternal<EntityType>;\n\n    /**\n     * All validation errors of the entity.\n     */\n    validationErrors!: ValidationError[];\n    /**\n     * Whether or not the entity is valid.\n     */\n    isEntityValid: boolean = false;\n    /**\n     * Whether or not the entity is dirty.\n     */\n    isEntityDirty: boolean = false;\n    /**\n     * What to display inside the tooltip.\n     */\n    tooltipContent: string = '';\n\n    private inConfirmNavigation: boolean = false;\n\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    get hasUnsavedChanges(): boolean {\n        return this.isEntityDirty && this.data.createData.unsavedChangesRequireConfirmDialog;\n    }\n\n    constructor(\n        private readonly dialog: MatDialog,\n        private readonly location: Location,\n        private readonly injector: EnvironmentInjector,\n        @Inject(NGX_CREATE_DATA_ENTITY_SERVICE)\n        readonly entityService: EntityService<EntityType>,\n        @Inject(NGX_CREATE_DATA_ENTITY)\n        private readonly EntityClass: EntityClassNewable<EntityType>,\n        @Inject(NGX_CREATE_DATA)\n        private readonly inputData: PageCreateData<EntityType>,\n        private readonly http: HttpClient,\n        private readonly el: ElementRef,\n        private readonly renderer: Renderer2,\n        @Inject(NGX_INTERNAL_GLOBAL_DEFAULT_VALUES)\n        protected readonly globalConfig: NgxGlobalDefaultValues\n    ) { }\n\n    ngOnInit(): void {\n        this.data = new PageCreateDataBuilder(this.inputData, this.globalConfig).getResult();\n        if (this.data == null) {\n            this.confirmNavigateBack();\n            // eslint-disable-next-line max-len\n            throw new Error('No create data was provided for \"NGX_CREATE_DATA\". You need to provide a value in your routes providers array.');\n        }\n\n        this.entity = new this.EntityClass();\n        EntityUtilities.setDefaultValues(this.entity);\n        this.entityPriorChanges = LodashUtilities.cloneDeep(this.entity);\n        this.checkIsEntityValid();\n\n        this.entityTabs = EntityUtilities.getEntityTabs(this.entity, this.injector, true, false);\n        setTimeout(() => this.checkOffset(), 1);\n        // setTimeout(() => this.checkEntity(), 1);\n    }\n\n    /**\n     * Whether the page can be left without confirmation (of unsaved changes).\n     * @returns Whether or not the page can be left without confirmation.\n     */\n    @HostListener('window:beforeunload')\n    canDeactivate(): boolean {\n        return !this.hasUnsavedChanges || this.inConfirmNavigation;\n    }\n\n    /**\n     * Checks if the bottom row should be displayed as fixed.\n     */\n    @HostListener('window:scroll')\n    checkOffset(): void {\n        const scrollY: number = window.scrollY;\n        const bottomRow: HTMLElement | null = (this.el.nativeElement as HTMLElement).querySelector('.bottom-row');\n        const bottomRowContainer: HTMLElement | null = (this.el.nativeElement as HTMLElement).querySelector('.bottom-row-container');\n\n        if (bottomRow && bottomRowContainer) {\n            const bottomRowContainerOffset: number = bottomRowContainer.offsetTop;\n            const windowHeight: number = window.innerHeight;\n\n            if (scrollY + windowHeight >= bottomRowContainerOffset) {\n                this.renderer.removeClass(bottomRow, 'fixed');\n            }\n            else {\n                this.renderer.addClass(bottomRow, 'fixed');\n            }\n        }\n    }\n\n    /**\n     * Checks if the entity has become invalid or dirty.\n     */\n    async checkEntity(): Promise<void> {\n        this.checkIsEntityValid();\n        this.isEntityDirty = await EntityUtilities.isDirty(this.entity, this.entityPriorChanges, this.http);\n    }\n\n    private checkIsEntityValid(): void {\n        this.validationErrors = ValidationUtilities.getEntityValidationErrors(this.entity, 'create');\n        this.tooltipContent = runInInjectionContext(this.injector, () => getValidationErrorsTooltipContent(this.validationErrors));\n        this.isEntityValid = this.validationErrors.length === 0;\n    }\n\n    /**\n     * Tries create the entity and navigate back afterwards.\n     * Also handles the confirmation if required.\n     */\n    create(): void {\n        if (!this.isEntityValid) {\n            return;\n        }\n        if (!this.data.createData.createRequiresConfirmDialog) {\n            this.confirmCreate();\n            return;\n        }\n        // eslint-disable-next-line max-len\n        const dialogData: ConfirmDialogDataInternal = new ConfirmDialogDataBuilder(this.globalConfig, this.data.createData.confirmCreateDialogData)\n            .withDefault('text', this.globalConfig.confirmCreateText)\n            .withDefault('confirmButtonLabel', this.globalConfig.createLabel)\n            .withDefault('title', this.globalConfig.createLabel)\n            .getResult();\n        const dialogRef: MatDialogRef<NgxMatEntityConfirmDialogComponent, boolean> = this.dialog.open(NgxMatEntityConfirmDialogComponent, {\n            data: dialogData,\n            autoFocus: false,\n            restoreFocus: false\n        });\n        dialogRef.afterClosed().subscribe(res => {\n            if (res == true) {\n                this.confirmCreate();\n            }\n        });\n    }\n\n    private confirmCreate(): void {\n        void this.entityService.create(this.entity).then(() => this.confirmNavigateBack());\n    }\n\n    /**\n     * Tries to navigate back.\n     */\n    navigateBack(): void {\n        if (!this.hasUnsavedChanges) {\n            this.confirmNavigateBack();\n            return;\n        }\n\n        this.openConfirmNavigationDialog().subscribe(res => {\n            if (res) {\n                this.confirmNavigateBack();\n            }\n        });\n    }\n\n    /**\n     * Opens the confirm dialog for navigating with unsaved changes.\n     * This is exposed because the UnsavedChangesGuard needs to access this.\n     * @returns The first observable result of the confirm dialog.\n     */\n    openConfirmNavigationDialog(): Observable<boolean> {\n        const dialogRef: MatDialogRef<NgxMatEntityConfirmDialogComponent, boolean> = this.dialog.open(NgxMatEntityConfirmDialogComponent, {\n            data: this.data.createData.confirmUnsavedChangesDialogData,\n            autoFocus: false,\n            restoreFocus: false\n        });\n        return dialogRef.afterClosed().pipe(first(), map(p => (p ?? false)));\n    }\n\n    private confirmNavigateBack(): void {\n        this.inConfirmNavigation = true;\n        this.location.back();\n    }\n\n    /**\n     * Checks if the input with the given key is readonly.\n     * @param key - The key for the input to check.\n     * @returns Whether or not the input for the key is read only.\n     */\n    isReadOnly(key: keyof EntityType): boolean {\n        return runInInjectionContext(this.injector, () => {\n            const metadata: PropertyDecoratorConfigInternal<unknown> = EntityUtilities.getPropertyMetadata(this.entity, key);\n            return metadata.isReadOnly(this.entity);\n        });\n    }\n}","<!-- eslint-disable angular/no-call-expression -->\n<!-- eslint-disable angular/cyclomatic-complexity -->\n<div *ngIf=\"!entityTabs && data.displayLoadingSpinner\" class=\"container\">\n    <br>\n    <mat-spinner></mat-spinner>\n    <br>\n</div>\n\n<div *ngIf=\"entityTabs\" class=\"container\">\n    <br>\n\n    <!------------>\n    <!-- Header -->\n    <!------------>\n    <div class=\"header\">\n        <div class=\"cancel-container\">\n            <button type=\"button\" mat-raised-button class=\"back-button\" tabindex=\"-1\" [class.unsavedChanges]=\"hasUnsavedChanges\" (click)=\"navigateBack()\">\n                <i class=\"fas fa-chevron-left\"></i>\n                {{data.createData.cancelButtonLabel}}\n                <i *ngIf=\"hasUnsavedChanges\" class=\"fas fa-warning\"></i>\n            </button>\n        </div>\n    </div>\n\n    <h1>{{data.createData.title}}</h1>\n\n    <!----------->\n    <!-- Input -->\n    <!----------->\n    <form>\n        <mat-tab-group *ngIf=\"entityTabs.length > 1\" preserveContent (selectedTabChange)=\"checkOffset()\">\n            <mat-tab *ngFor=\"let tab of entityTabs\" [label]=\"tab.tabName\">\n                <div *ngFor=\"let row of tab.rows\" class=\"row\">\n                    <ngx-mat-entity-input\n                        *ngFor=\"let key of row.keys\"\n                        [entity]=\"entity\"\n                        [propertyKey]=\"key\"\n                        [hideOmitForEdit]=\"true\"\n                        [class]=\"EntityUtilities.getWidthClasses(entity, key)\"\n                        [isReadOnly]=\"isReadOnly(key)\"\n                        (inputChangeEvent)=\"checkEntity()\"\n                    >\n                    </ngx-mat-entity-input>\n                </div>\n            </mat-tab>\n        </mat-tab-group>\n    \n        <div *ngIf=\"entityTabs.length <= 1\">\n            <span *ngIf=\"!entityTabs.length\" class=\"no-entity-tabs\">\n                ERROR: No Inputs. Did you correctly assign all values in the model constructor?\n            </span>\n            <div *ngFor=\"let row of entityTabs[0]?.rows\" class=\"row\">\n                <ngx-mat-entity-input\n                    *ngFor=\"let key of row.keys\"\n                    [entity]=\"entity\"\n                    [propertyKey]=\"key\"\n                    [hideOmitForEdit]=\"true\"\n                    [class]=\"EntityUtilities.getWidthClasses(entity, key)\"\n                    [isReadOnly]=\"isReadOnly(key)\"\n                    (inputChangeEvent)=\"checkEntity()\"\n                >\n                </ngx-mat-entity-input>\n            </div>\n        </div>\n\n        <div class=\"bottom-row-container\">\n            <div class=\"bottom-row container\" style=\"margin-top: 10px;\">\n                <button type=\"submit\" mat-raised-button matBadgeColor=\"warn\"\n                    [disabled]=\"!isEntityValid || !isEntityDirty\"\n                    [matBadge]=\"validationErrors.length\"\n                    [matBadgeHidden]=\"!validationErrors.length\"\n                    (click)=\"create()\"\n                >\n                    {{data.createData.createButtonLabel}}\n                </button>\n                <ngx-mat-entity-tooltip *ngIf=\"validationErrors.length\" [tooltipContent]=\"tooltipContent\"></ngx-mat-entity-tooltip>\n            </div>\n        </div>\n    </form>\n\n    <br>\n</div>"]}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { BaseBuilder } from '../../classes/base.builder';
|
|
2
|
+
import { ConfirmDialogDataBuilder } from '../confirm-dialog/confirm-dialog-data.builder';
|
|
3
|
+
import { CreateDataBuilder } from '../table/create-dialog/create-data.builder';
|
|
4
|
+
// eslint-disable-next-line jsdoc/require-jsdoc
|
|
5
|
+
export class PageCreateDataBuilder extends BaseBuilder {
|
|
6
|
+
constructor(data, globalConfig) {
|
|
7
|
+
super(globalConfig, data);
|
|
8
|
+
}
|
|
9
|
+
// eslint-disable-next-line jsdoc/require-jsdoc
|
|
10
|
+
generateBaseData(data) {
|
|
11
|
+
const createData = new CreateDataBuilder(this.globalConfig, data.createData)
|
|
12
|
+
.withDefault('cancelButtonLabel', this.globalConfig.backLabel)
|
|
13
|
+
.getResult();
|
|
14
|
+
// eslint-disable-next-line max-len
|
|
15
|
+
const confirmUnsavedChangesDialogData = new ConfirmDialogDataBuilder(this.globalConfig, data.createData?.confirmUnsavedChangesDialogData)
|
|
16
|
+
.withDefault('title', this.globalConfig.confirmUnsavedChangesTitle)
|
|
17
|
+
.withDefault('text', this.globalConfig.confirmUnsavedChangesText)
|
|
18
|
+
.withDefault('confirmButtonLabel', this.globalConfig.confirmUnsavedChangesLabel)
|
|
19
|
+
.getResult();
|
|
20
|
+
return {
|
|
21
|
+
createData: {
|
|
22
|
+
...createData,
|
|
23
|
+
confirmUnsavedChangesDialogData: confirmUnsavedChangesDialogData,
|
|
24
|
+
unsavedChangesRequireConfirmDialog: data.createData?.unsavedChangesRequireConfirmDialog ?? true
|
|
25
|
+
},
|
|
26
|
+
displayLoadingSpinner: data.displayLoadingSpinner ?? true
|
|
27
|
+
};
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFnZS1jcmVhdGUtZGF0YS5idWlsZGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LW1hdGVyaWFsLWVudGl0eS9zcmMvY29tcG9uZW50cy9jcmVhdGUtcGFnZS9wYWdlLWNyZWF0ZS1kYXRhLmJ1aWxkZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBR3pELE9BQU8sRUFBRSx3QkFBd0IsRUFBNkIsTUFBTSwrQ0FBK0MsQ0FBQztBQUNwSCxPQUFPLEVBQUUsaUJBQWlCLEVBQXNCLE1BQU0sNENBQTRDLENBQUM7QUFpQm5HLCtDQUErQztBQUMvQyxNQUFNLE9BQU8scUJBQ1QsU0FBUSxXQUEyRTtJQUVuRixZQUFZLElBQWdDLEVBQUUsWUFBb0M7UUFDOUUsS0FBSyxDQUFDLFlBQVksRUFBRSxJQUFJLENBQUMsQ0FBQztJQUM5QixDQUFDO0lBRUQsK0NBQStDO0lBQ3JDLGdCQUFnQixDQUFDLElBQWdDO1FBQ3ZELE1BQU0sVUFBVSxHQUF1QixJQUFJLGlCQUFpQixDQUFDLElBQUksQ0FBQyxZQUFZLEVBQUUsSUFBSSxDQUFDLFVBQVUsQ0FBQzthQUMzRixXQUFXLENBQUMsbUJBQW1CLEVBQUUsSUFBSSxDQUFDLFlBQVksQ0FBQyxTQUFTLENBQUM7YUFDN0QsU0FBUyxFQUFFLENBQUM7UUFDakIsbUNBQW1DO1FBQ25DLE1BQU0sK0JBQStCLEdBQThCLElBQUksd0JBQXdCLENBQUMsSUFBSSxDQUFDLFlBQVksRUFBRSxJQUFJLENBQUMsVUFBVSxFQUFFLCtCQUErQixDQUFDO2FBQy9KLFdBQVcsQ0FBQyxPQUFPLEVBQUUsSUFBSSxDQUFDLFlBQVksQ0FBQywwQkFBMEIsQ0FBQzthQUNsRSxXQUFXLENBQUMsTUFBTSxFQUFFLElBQUksQ0FBQyxZQUFZLENBQUMseUJBQXlCLENBQUM7YUFDaEUsV0FBVyxDQUFDLG9CQUFvQixFQUFFLElBQUksQ0FBQyxZQUFZLENBQUMsMEJBQTBCLENBQUM7YUFDL0UsU0FBUyxFQUFFLENBQUM7UUFFakIsT0FBTztZQUNILFVBQVUsRUFBRTtnQkFDUixHQUFHLFVBQVU7Z0JBQ2IsK0JBQStCLEVBQUUsK0JBQStCO2dCQUNoRSxrQ0FBa0MsRUFBRSxJQUFJLENBQUMsVUFBVSxFQUFFLGtDQUFrQyxJQUFJLElBQUk7YUFDbEc7WUFDRCxxQkFBcUIsRUFBRSxJQUFJLENBQUMscUJBQXFCLElBQUksSUFBSTtTQUM1RCxDQUFDO0lBQ04sQ0FBQztDQUNKIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQmFzZUJ1aWxkZXIgfSBmcm9tICcuLi8uLi9jbGFzc2VzL2Jhc2UuYnVpbGRlcic7XG5pbXBvcnQgeyBCYXNlRW50aXR5VHlwZSB9IGZyb20gJy4uLy4uL2NsYXNzZXMvZW50aXR5Lm1vZGVsJztcbmltcG9ydCB7IE5neEdsb2JhbERlZmF1bHRWYWx1ZXMgfSBmcm9tICcuLi8uLi9nbG9iYWwtY29uZmlndXJhdGlvbi12YWx1ZXMnO1xuaW1wb3J0IHsgQ29uZmlybURpYWxvZ0RhdGFCdWlsZGVyLCBDb25maXJtRGlhbG9nRGF0YUludGVybmFsIH0gZnJvbSAnLi4vY29uZmlybS1kaWFsb2cvY29uZmlybS1kaWFsb2ctZGF0YS5idWlsZGVyJztcbmltcG9ydCB7IENyZWF0ZURhdGFCdWlsZGVyLCBDcmVhdGVEYXRhSW50ZXJuYWwgfSBmcm9tICcuLi90YWJsZS9jcmVhdGUtZGlhbG9nL2NyZWF0ZS1kYXRhLmJ1aWxkZXInO1xuaW1wb3J0IHsgQ3JlYXRlRW50aXR5RGF0YUludGVybmFsIH0gZnJvbSAnLi4vdGFibGUvY3JlYXRlLWRpYWxvZy9jcmVhdGUtZW50aXR5LWRpYWxvZy1kYXRhLmJ1aWxkZXInO1xuaW1wb3J0IHsgUGFnZUNyZWF0ZURhdGEgfSBmcm9tICcuL2NyZWF0ZS1wYWdlLmNvbXBvbmVudCc7XG5cbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBqc2RvYy9yZXF1aXJlLWpzZG9jLCBtYXgtbGVuXG5leHBvcnQgdHlwZSBQYWdlQ3JlYXRlRGF0YUludGVybmFsPEVudGl0eVR5cGUgZXh0ZW5kcyBCYXNlRW50aXR5VHlwZTxFbnRpdHlUeXBlPj4gPSBPbWl0PENyZWF0ZUVudGl0eURhdGFJbnRlcm5hbDxFbnRpdHlUeXBlPiwgJ2VudGl0eScgfCAnRW50aXR5U2VydmljZUNsYXNzJz4gJiB7XG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIGpzZG9jL3JlcXVpcmUtanNkb2NcbiAgICBkaXNwbGF5TG9hZGluZ1NwaW5uZXI6IGJvb2xlYW4sXG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIGpzZG9jL3JlcXVpcmUtanNkb2NcbiAgICBjcmVhdGVEYXRhOiBDcmVhdGVEYXRhSW50ZXJuYWwgJiB7XG4gICAgICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBqc2RvYy9yZXF1aXJlLWpzZG9jXG4gICAgICAgIGNvbmZpcm1VbnNhdmVkQ2hhbmdlc0RpYWxvZ0RhdGE6IENvbmZpcm1EaWFsb2dEYXRhSW50ZXJuYWwsXG4gICAgICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBqc2RvYy9yZXF1aXJlLWpzZG9jXG4gICAgICAgIHVuc2F2ZWRDaGFuZ2VzUmVxdWlyZUNvbmZpcm1EaWFsb2c6IGJvb2xlYW5cbiAgICB9XG59O1xuXG4vLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUganNkb2MvcmVxdWlyZS1qc2RvY1xuZXhwb3J0IGNsYXNzIFBhZ2VDcmVhdGVEYXRhQnVpbGRlcjxFbnRpdHlUeXBlIGV4dGVuZHMgQmFzZUVudGl0eVR5cGU8RW50aXR5VHlwZT4+XG4gICAgZXh0ZW5kcyBCYXNlQnVpbGRlcjxQYWdlQ3JlYXRlRGF0YUludGVybmFsPEVudGl0eVR5cGU+LCBQYWdlQ3JlYXRlRGF0YTxFbnRpdHlUeXBlPj4ge1xuXG4gICAgY29uc3RydWN0b3IoZGF0YTogUGFnZUNyZWF0ZURhdGE8RW50aXR5VHlwZT4sIGdsb2JhbENvbmZpZzogTmd4R2xvYmFsRGVmYXVsdFZhbHVlcykge1xuICAgICAgICBzdXBlcihnbG9iYWxDb25maWcsIGRhdGEpO1xuICAgIH1cblxuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBqc2RvYy9yZXF1aXJlLWpzZG9jXG4gICAgcHJvdGVjdGVkIGdlbmVyYXRlQmFzZURhdGEoZGF0YTogUGFnZUNyZWF0ZURhdGE8RW50aXR5VHlwZT4pOiBQYWdlQ3JlYXRlRGF0YUludGVybmFsPEVudGl0eVR5cGU+IHtcbiAgICAgICAgY29uc3QgY3JlYXRlRGF0YTogQ3JlYXRlRGF0YUludGVybmFsID0gbmV3IENyZWF0ZURhdGFCdWlsZGVyKHRoaXMuZ2xvYmFsQ29uZmlnLCBkYXRhLmNyZWF0ZURhdGEpXG4gICAgICAgICAgICAud2l0aERlZmF1bHQoJ2NhbmNlbEJ1dHRvbkxhYmVsJywgdGhpcy5nbG9iYWxDb25maWcuYmFja0xhYmVsKVxuICAgICAgICAgICAgLmdldFJlc3VsdCgpO1xuICAgICAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgbWF4LWxlblxuICAgICAgICBjb25zdCBjb25maXJtVW5zYXZlZENoYW5nZXNEaWFsb2dEYXRhOiBDb25maXJtRGlhbG9nRGF0YUludGVybmFsID0gbmV3IENvbmZpcm1EaWFsb2dEYXRhQnVpbGRlcih0aGlzLmdsb2JhbENvbmZpZywgZGF0YS5jcmVhdGVEYXRhPy5jb25maXJtVW5zYXZlZENoYW5nZXNEaWFsb2dEYXRhKVxuICAgICAgICAgICAgLndpdGhEZWZhdWx0KCd0aXRsZScsIHRoaXMuZ2xvYmFsQ29uZmlnLmNvbmZpcm1VbnNhdmVkQ2hhbmdlc1RpdGxlKVxuICAgICAgICAgICAgLndpdGhEZWZhdWx0KCd0ZXh0JywgdGhpcy5nbG9iYWxDb25maWcuY29uZmlybVVuc2F2ZWRDaGFuZ2VzVGV4dClcbiAgICAgICAgICAgIC53aXRoRGVmYXVsdCgnY29uZmlybUJ1dHRvbkxhYmVsJywgdGhpcy5nbG9iYWxDb25maWcuY29uZmlybVVuc2F2ZWRDaGFuZ2VzTGFiZWwpXG4gICAgICAgICAgICAuZ2V0UmVzdWx0KCk7XG5cbiAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICAgIGNyZWF0ZURhdGE6IHtcbiAgICAgICAgICAgICAgICAuLi5jcmVhdGVEYXRhLFxuICAgICAgICAgICAgICAgIGNvbmZpcm1VbnNhdmVkQ2hhbmdlc0RpYWxvZ0RhdGE6IGNvbmZpcm1VbnNhdmVkQ2hhbmdlc0RpYWxvZ0RhdGEsXG4gICAgICAgICAgICAgICAgdW5zYXZlZENoYW5nZXNSZXF1aXJlQ29uZmlybURpYWxvZzogZGF0YS5jcmVhdGVEYXRhPy51bnNhdmVkQ2hhbmdlc1JlcXVpcmVDb25maXJtRGlhbG9nID8/IHRydWVcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgICBkaXNwbGF5TG9hZGluZ1NwaW5uZXI6IGRhdGEuZGlzcGxheUxvYWRpbmdTcGlubmVyID8/IHRydWVcbiAgICAgICAgfTtcbiAgICB9XG59Il19
|
|
@@ -1,8 +1,11 @@
|
|
|
1
1
|
import { UnsavedChangesGuard } from '../../services/unsaved-changes.guard';
|
|
2
|
+
/**
|
|
3
|
+
* The default data for a edit route.
|
|
4
|
+
*/
|
|
2
5
|
export const defaultEditDataRoute = {
|
|
3
6
|
loadComponent: () => import('./edit-page.component').then(m => m.NgxMatEntityEditPageComponent),
|
|
4
7
|
title: 'Edit',
|
|
5
8
|
path: 'entities:id',
|
|
6
9
|
canDeactivate: [UnsavedChangesGuard]
|
|
7
10
|
};
|
|
8
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
11
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWRpdC1kYXRhLnJvdXRlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LW1hdGVyaWFsLWVudGl0eS9zcmMvY29tcG9uZW50cy9lZGl0LXBhZ2UvZWRpdC1kYXRhLnJvdXRlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUdBLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHNDQUFzQyxDQUFDO0FBZ0IzRTs7R0FFRztBQUNILE1BQU0sQ0FBQyxNQUFNLG9CQUFvQixHQUFxQztJQUNsRSxhQUFhLEVBQUUsR0FBRyxFQUFFLENBQUMsTUFBTSxDQUFDLHVCQUF1QixDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLDZCQUE2QixDQUFDO0lBQy9GLEtBQUssRUFBRSxNQUFNO0lBQ2IsSUFBSSxFQUFFLGFBQWE7SUFDbkIsYUFBYSxFQUFFLENBQUMsbUJBQW1CLENBQUM7Q0FDdkMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEVudmlyb25tZW50UHJvdmlkZXJzLCBQcm92aWRlciwgVHlwZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRGVmYXVsdEV4cG9ydCwgUm91dGUgfSBmcm9tICdAYW5ndWxhci9yb3V0ZXInO1xuaW1wb3J0IHsgT2JzZXJ2YWJsZSB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgVW5zYXZlZENoYW5nZXNHdWFyZCB9IGZyb20gJy4uLy4uL3NlcnZpY2VzL3Vuc2F2ZWQtY2hhbmdlcy5ndWFyZCc7XG5cbi8qKlxuICogVGhlIGRlZmluaXRpb24gZm9yIGEgcm91dGUgdG8gdXNlIHdpdGggdGhlIFwiTmd4TWF0RW50aXR5RWRpdFBhZ2VDb21wb25lbnRcIi5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBFZGl0RGF0YVJvdXRlIGV4dGVuZHMgUm91dGUge1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBtYXgtbGVuLCBqc2RvYy9yZXF1aXJlLWpzZG9jXG4gICAgbG9hZENvbXBvbmVudDogKCkgPT4gVHlwZTx1bmtub3duPiB8IE9ic2VydmFibGU8VHlwZTx1bmtub3duPiB8IERlZmF1bHRFeHBvcnQ8VHlwZTx1bmtub3duPj4+IHwgUHJvbWlzZTxUeXBlPHVua25vd24+IHwgRGVmYXVsdEV4cG9ydDxUeXBlPHVua25vd24+Pj4sXG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIGpzZG9jL3JlcXVpcmUtanNkb2NcbiAgICBwcm92aWRlcnM6IChQcm92aWRlciB8IEVudmlyb25tZW50UHJvdmlkZXJzKVtdLFxuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBqc2RvYy9yZXF1aXJlLWpzZG9jXG4gICAgdGl0bGU6IHN0cmluZyxcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUganNkb2MvcmVxdWlyZS1qc2RvY1xuICAgIHBhdGg6IHN0cmluZ1xufVxuXG4vKipcbiAqIFRoZSBkZWZhdWx0IGRhdGEgZm9yIGEgZWRpdCByb3V0ZS5cbiAqL1xuZXhwb3J0IGNvbnN0IGRlZmF1bHRFZGl0RGF0YVJvdXRlOiBPbWl0PEVkaXREYXRhUm91dGUsICdwcm92aWRlcnMnPiA9IHtcbiAgICBsb2FkQ29tcG9uZW50OiAoKSA9PiBpbXBvcnQoJy4vZWRpdC1wYWdlLmNvbXBvbmVudCcpLnRoZW4obSA9PiBtLk5neE1hdEVudGl0eUVkaXRQYWdlQ29tcG9uZW50KSxcbiAgICB0aXRsZTogJ0VkaXQnLFxuICAgIHBhdGg6ICdlbnRpdGllczppZCcsXG4gICAgY2FuRGVhY3RpdmF0ZTogW1Vuc2F2ZWRDaGFuZ2VzR3VhcmRdXG59OyJdfQ==
|