@indigina/kendo 1.1.25 → 1.1.26

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.
@@ -1,4 +1,4 @@
1
- import { ViewChild, Component, Input } from '@angular/core';
1
+ import { ViewChild, Component, Input, } from '@angular/core';
2
2
  import { UntypedFormControl } from '@angular/forms';
3
3
  import { FormGroupWithErrors } from '../../angular/forms/extensions/FormGroupWithErrors';
4
4
  import { finalize } from 'rxjs/operators';
@@ -16,30 +16,39 @@ export class EntityEditFormComponent {
16
16
  this.formGroup = new BehaviorSubject(null);
17
17
  this.saveInProgress = false;
18
18
  }
19
+ ngOnChanges() {
20
+ if (this.entityId) {
21
+ this.loadEntity(this.entityId);
22
+ }
23
+ }
19
24
  ngOnDestroy() {
20
25
  this.routeService.unsubscribe();
21
26
  }
22
27
  ngOnInit() {
23
- this.routeService = this.route.params.subscribe((params) => {
24
- this.formGroup.next(null);
25
- const formGroup = new FormGroupWithErrors({});
26
- if (params.id) {
27
- this.adapter
28
- .getService()
29
- .get(params.id, this.adapter.getUrlParams())
30
- .subscribe((model) => {
31
- formGroup.addControl('id', new UntypedFormControl(model.id));
32
- for (const key of Object.keys(model)) {
33
- formGroup.addControl(key, new UntypedFormControl(model[key]));
34
- }
35
- this.adapter.setForm(formGroup);
36
- this.formGroup.next(formGroup);
37
- });
38
- }
39
- else {
40
- this.adapter.setForm(formGroup);
41
- this.formGroup.next(formGroup);
28
+ if (!this.entityId) {
29
+ this.routeService = this.route.params.subscribe((params) => {
30
+ this.loadEntity(params.id);
31
+ });
32
+ }
33
+ }
34
+ loadEntity(id) {
35
+ this.formGroup.next(null);
36
+ const formGroup = new FormGroupWithErrors({});
37
+ if (!id) {
38
+ this.adapter.setForm(formGroup);
39
+ this.formGroup.next(formGroup);
40
+ return;
41
+ }
42
+ this.adapter
43
+ .getService()
44
+ .get(id, this.adapter.getUrlParams())
45
+ .subscribe((model) => {
46
+ formGroup.addControl('id', new UntypedFormControl(model.id));
47
+ for (const key of Object.keys(model)) {
48
+ formGroup.addControl(key, new UntypedFormControl(model[key]));
42
49
  }
50
+ this.adapter.setForm(formGroup);
51
+ this.formGroup.next(formGroup);
43
52
  });
44
53
  }
45
54
  save() {
@@ -57,7 +66,7 @@ export class EntityEditFormComponent {
57
66
  }
58
67
  }
59
68
  EntityEditFormComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.4", ngImport: i0, type: EntityEditFormComponent, deps: [{ token: i1.ActivatedRoute }], target: i0.ɵɵFactoryTarget.Component });
60
- EntityEditFormComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.4", type: EntityEditFormComponent, selector: "entity-edit-form", inputs: { title: "title", adapter: "adapter" }, viewQueries: [{ propertyName: "generalErrors", first: true, predicate: ["general_errors"], descendants: true }], ngImport: i0, template: "<div class=\"col-md-8\">\n <header class=\"header-page-bg\">\n <h4>{{ title | translate }}</h4>\n </header>\n <div class=\"panel editor-area hero-unit\">\n <form\n class=\"form-horizontal\"\n [formGroup]=\"formGroup | async\"\n novalidate\n autocomplete=\"off\"\n *ngIf=\"formGroup | async\"\n >\n <div class=\"col-md-3\"></div>\n <div class=\"col-md-9\">\n <app-general-errors\n #general_errors\n [form]=\"formGroup | async\"\n ></app-general-errors>\n </div>\n <ng-content></ng-content>\n <entity-edit-buttons-bar\n (save)=\"save()\"\n [valid]=\"\n formGroup.value.valid && formGroup.value.dirty && !saveInProgress\n \"\n >\n </entity-edit-buttons-bar>\n </form>\n </div>\n</div>\n", styles: [""], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.GeneralErrorsComponent, selector: "app-general-errors", inputs: ["form"] }, { kind: "directive", type: i4.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i4.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i4.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "component", type: i5.EntityEditButtonsBarComponent, selector: "entity-edit-buttons-bar", inputs: ["valid"], outputs: ["save"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "pipe", type: i6.TranslatePipe, name: "translate" }] });
69
+ EntityEditFormComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.4", type: EntityEditFormComponent, selector: "entity-edit-form", inputs: { title: "title", entityId: "entityId", adapter: "adapter" }, viewQueries: [{ propertyName: "generalErrors", first: true, predicate: ["general_errors"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"col-md-8\">\n <header class=\"header-page-bg\">\n <h4>{{ title | translate }}</h4>\n </header>\n <div class=\"panel editor-area hero-unit\">\n <form\n class=\"form-horizontal\"\n [formGroup]=\"formGroup | async\"\n novalidate\n autocomplete=\"off\"\n *ngIf=\"formGroup | async\"\n >\n <div class=\"col-md-3\"></div>\n <div class=\"col-md-9\">\n <app-general-errors\n #general_errors\n [form]=\"formGroup | async\"\n ></app-general-errors>\n </div>\n <ng-content></ng-content>\n <entity-edit-buttons-bar\n (save)=\"save()\"\n [valid]=\"\n formGroup.value.valid && formGroup.value.dirty && !saveInProgress\n \"\n >\n </entity-edit-buttons-bar>\n </form>\n </div>\n</div>\n", styles: [""], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.GeneralErrorsComponent, selector: "app-general-errors", inputs: ["form"] }, { kind: "directive", type: i4.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i4.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i4.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "component", type: i5.EntityEditButtonsBarComponent, selector: "entity-edit-buttons-bar", inputs: ["valid"], outputs: ["save"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "pipe", type: i6.TranslatePipe, name: "translate" }] });
61
70
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.4", ngImport: i0, type: EntityEditFormComponent, decorators: [{
62
71
  type: Component,
63
72
  args: [{ selector: 'entity-edit-form', template: "<div class=\"col-md-8\">\n <header class=\"header-page-bg\">\n <h4>{{ title | translate }}</h4>\n </header>\n <div class=\"panel editor-area hero-unit\">\n <form\n class=\"form-horizontal\"\n [formGroup]=\"formGroup | async\"\n novalidate\n autocomplete=\"off\"\n *ngIf=\"formGroup | async\"\n >\n <div class=\"col-md-3\"></div>\n <div class=\"col-md-9\">\n <app-general-errors\n #general_errors\n [form]=\"formGroup | async\"\n ></app-general-errors>\n </div>\n <ng-content></ng-content>\n <entity-edit-buttons-bar\n (save)=\"save()\"\n [valid]=\"\n formGroup.value.valid && formGroup.value.dirty && !saveInProgress\n \"\n >\n </entity-edit-buttons-bar>\n </form>\n </div>\n</div>\n" }]
@@ -66,7 +75,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.4", ngImpor
66
75
  args: ['general_errors']
67
76
  }], title: [{
68
77
  type: Input
78
+ }], entityId: [{
79
+ type: Input
69
80
  }], adapter: [{
70
81
  type: Input
71
82
  }] } });
72
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"entity-edit-form.component.js","sourceRoot":"","sources":["../../../../../../projects/kendo/src/lib/widgets/entity-edit/entity-edit-form.component.ts","../../../../../../projects/kendo/src/lib/widgets/entity-edit/entity-edit-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { OnInit, ViewChild, Component, Input, OnDestroy } from '@angular/core';\nimport { ActivatedRoute } from '@angular/router';\nimport { HttpErrorResponse } from '@angular/common/http';\nimport { UntypedFormControl } from '@angular/forms';\nimport { IFormAdapter } from './IFormAdapter';\nimport { FormGroupWithErrors } from '../../angular/forms/extensions/FormGroupWithErrors';\nimport { GeneralErrorsComponent } from '../../angular/forms/widgets/general-errors/general-errors.component';\nimport { IdentifiedModel } from '../../angular/models/IdentifiedModel';\nimport { finalize } from 'rxjs/operators';\nimport { BehaviorSubject, Subscription } from 'rxjs';\n\n@Component({\n  selector: 'entity-edit-form',\n  templateUrl: './entity-edit-form.component.html',\n  styleUrls: ['./entity-edit-form.component.css'],\n})\nexport class EntityEditFormComponent implements OnInit, OnDestroy {\n  public formGroup: BehaviorSubject<FormGroupWithErrors> =\n    new BehaviorSubject<FormGroupWithErrors>(null);\n  @ViewChild('general_errors')\n  generalErrors: GeneralErrorsComponent;\n  @Input()\n  title: string;\n  @Input()\n  adapter: IFormAdapter<IdentifiedModel>;\n  routeService: Subscription;\n\n  public saveInProgress: boolean;\n\n  constructor(private route: ActivatedRoute) {\n    this.saveInProgress = false;\n  }\n\n  ngOnDestroy(): void {\n    this.routeService.unsubscribe();\n  }\n\n  ngOnInit() {\n    this.routeService = this.route.params.subscribe(\n      (params: IdentifiedModel) => {\n        this.formGroup.next(null);\n        const formGroup = new FormGroupWithErrors({});\n        if (params.id) {\n          this.adapter\n            .getService()\n            .get(params.id, this.adapter.getUrlParams())\n            .subscribe((model) => {\n              formGroup.addControl('id', new UntypedFormControl(model.id));\n              for (const key of Object.keys(model)) {\n                formGroup.addControl(key, new UntypedFormControl(model[key]));\n              }\n\n              this.adapter.setForm(formGroup);\n              this.formGroup.next(formGroup);\n            });\n        } else {\n          this.adapter.setForm(formGroup);\n          this.formGroup.next(formGroup);\n        }\n      }\n    );\n  }\n\n  save(): void {\n    this.saveInProgress = true;\n    this.adapter\n      .getService()\n      .save(this.adapter.getValue(), this.adapter.getUrlParams())\n      .pipe(finalize(() => (this.saveInProgress = false)))\n      .subscribe(\n        (result: IdentifiedModel) => {\n          this.adapter.onSaved(result);\n        },\n        (error: HttpErrorResponse) => {\n          this.formGroup.value.applyServerErrors(\n            error.error,\n            this.formGroup.value\n          );\n          this.generalErrors.setErrors(this.formGroup.value.generalErrors);\n        }\n      );\n  }\n}\n","<div class=\"col-md-8\">\n  <header class=\"header-page-bg\">\n    <h4>{{ title | translate }}</h4>\n  </header>\n  <div class=\"panel editor-area hero-unit\">\n    <form\n      class=\"form-horizontal\"\n      [formGroup]=\"formGroup | async\"\n      novalidate\n      autocomplete=\"off\"\n      *ngIf=\"formGroup | async\"\n    >\n      <div class=\"col-md-3\"></div>\n      <div class=\"col-md-9\">\n        <app-general-errors\n          #general_errors\n          [form]=\"formGroup | async\"\n        ></app-general-errors>\n      </div>\n      <ng-content></ng-content>\n      <entity-edit-buttons-bar\n        (save)=\"save()\"\n        [valid]=\"\n          formGroup.value.valid && formGroup.value.dirty && !saveInProgress\n        \"\n      >\n      </entity-edit-buttons-bar>\n    </form>\n  </div>\n</div>\n"]}
83
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"entity-edit-form.component.js","sourceRoot":"","sources":["../../../../../../projects/kendo/src/lib/widgets/entity-edit/entity-edit-form.component.ts","../../../../../../projects/kendo/src/lib/widgets/entity-edit/entity-edit-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  OnInit,\n  ViewChild,\n  Component,\n  Input,\n  OnDestroy,\n  OnChanges,\n} from '@angular/core';\nimport { ActivatedRoute } from '@angular/router';\nimport { HttpErrorResponse } from '@angular/common/http';\nimport { UntypedFormControl } from '@angular/forms';\nimport { IFormAdapter } from './IFormAdapter';\nimport { FormGroupWithErrors } from '../../angular/forms/extensions/FormGroupWithErrors';\nimport { GeneralErrorsComponent } from '../../angular/forms/widgets/general-errors/general-errors.component';\nimport { IdentifiedModel } from '../../angular/models/IdentifiedModel';\nimport { finalize } from 'rxjs/operators';\nimport { BehaviorSubject, Subscription } from 'rxjs';\n\n@Component({\n  selector: 'entity-edit-form',\n  templateUrl: './entity-edit-form.component.html',\n  styleUrls: ['./entity-edit-form.component.css'],\n})\nexport class EntityEditFormComponent implements OnInit, OnDestroy, OnChanges {\n  public formGroup: BehaviorSubject<FormGroupWithErrors> =\n    new BehaviorSubject<FormGroupWithErrors>(null);\n  @ViewChild('general_errors')\n  generalErrors: GeneralErrorsComponent;\n  @Input()\n  title: string;\n  @Input()\n  entityId?: string;\n  @Input()\n  adapter: IFormAdapter<IdentifiedModel>;\n  routeService: Subscription;\n\n  public saveInProgress: boolean;\n\n  constructor(private route: ActivatedRoute) {\n    this.saveInProgress = false;\n  }\n\n  ngOnChanges(): void {\n    if (this.entityId) {\n      this.loadEntity(this.entityId);\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.routeService.unsubscribe();\n  }\n\n  ngOnInit() {\n    if (!this.entityId) {\n      this.routeService = this.route.params.subscribe(\n        (params: IdentifiedModel) => {\n          this.loadEntity(params.id);\n        }\n      );\n    }\n  }\n\n  loadEntity(id?: string): void {\n    this.formGroup.next(null);\n    const formGroup = new FormGroupWithErrors({});\n    if (!id) {\n      this.adapter.setForm(formGroup);\n      this.formGroup.next(formGroup);\n\n      return;\n    }\n\n    this.adapter\n      .getService()\n      .get(id, this.adapter.getUrlParams())\n      .subscribe((model) => {\n        formGroup.addControl('id', new UntypedFormControl(model.id));\n        for (const key of Object.keys(model)) {\n          formGroup.addControl(key, new UntypedFormControl(model[key]));\n        }\n\n        this.adapter.setForm(formGroup);\n        this.formGroup.next(formGroup);\n      });\n  }\n\n  save(): void {\n    this.saveInProgress = true;\n    this.adapter\n      .getService()\n      .save(this.adapter.getValue(), this.adapter.getUrlParams())\n      .pipe(finalize(() => (this.saveInProgress = false)))\n      .subscribe(\n        (result: IdentifiedModel) => {\n          this.adapter.onSaved(result);\n        },\n        (error: HttpErrorResponse) => {\n          this.formGroup.value.applyServerErrors(\n            error.error,\n            this.formGroup.value\n          );\n          this.generalErrors.setErrors(this.formGroup.value.generalErrors);\n        }\n      );\n  }\n}\n","<div class=\"col-md-8\">\n  <header class=\"header-page-bg\">\n    <h4>{{ title | translate }}</h4>\n  </header>\n  <div class=\"panel editor-area hero-unit\">\n    <form\n      class=\"form-horizontal\"\n      [formGroup]=\"formGroup | async\"\n      novalidate\n      autocomplete=\"off\"\n      *ngIf=\"formGroup | async\"\n    >\n      <div class=\"col-md-3\"></div>\n      <div class=\"col-md-9\">\n        <app-general-errors\n          #general_errors\n          [form]=\"formGroup | async\"\n        ></app-general-errors>\n      </div>\n      <ng-content></ng-content>\n      <entity-edit-buttons-bar\n        (save)=\"save()\"\n        [valid]=\"\n          formGroup.value.valid && formGroup.value.dirty && !saveInProgress\n        \"\n      >\n      </entity-edit-buttons-bar>\n    </form>\n  </div>\n</div>\n"]}
@@ -2314,30 +2314,39 @@ class EntityEditFormComponent {
2314
2314
  this.formGroup = new BehaviorSubject(null);
2315
2315
  this.saveInProgress = false;
2316
2316
  }
2317
+ ngOnChanges() {
2318
+ if (this.entityId) {
2319
+ this.loadEntity(this.entityId);
2320
+ }
2321
+ }
2317
2322
  ngOnDestroy() {
2318
2323
  this.routeService.unsubscribe();
2319
2324
  }
2320
2325
  ngOnInit() {
2321
- this.routeService = this.route.params.subscribe((params) => {
2322
- this.formGroup.next(null);
2323
- const formGroup = new FormGroupWithErrors({});
2324
- if (params.id) {
2325
- this.adapter
2326
- .getService()
2327
- .get(params.id, this.adapter.getUrlParams())
2328
- .subscribe((model) => {
2329
- formGroup.addControl('id', new UntypedFormControl(model.id));
2330
- for (const key of Object.keys(model)) {
2331
- formGroup.addControl(key, new UntypedFormControl(model[key]));
2332
- }
2333
- this.adapter.setForm(formGroup);
2334
- this.formGroup.next(formGroup);
2335
- });
2336
- }
2337
- else {
2338
- this.adapter.setForm(formGroup);
2339
- this.formGroup.next(formGroup);
2326
+ if (!this.entityId) {
2327
+ this.routeService = this.route.params.subscribe((params) => {
2328
+ this.loadEntity(params.id);
2329
+ });
2330
+ }
2331
+ }
2332
+ loadEntity(id) {
2333
+ this.formGroup.next(null);
2334
+ const formGroup = new FormGroupWithErrors({});
2335
+ if (!id) {
2336
+ this.adapter.setForm(formGroup);
2337
+ this.formGroup.next(formGroup);
2338
+ return;
2339
+ }
2340
+ this.adapter
2341
+ .getService()
2342
+ .get(id, this.adapter.getUrlParams())
2343
+ .subscribe((model) => {
2344
+ formGroup.addControl('id', new UntypedFormControl(model.id));
2345
+ for (const key of Object.keys(model)) {
2346
+ formGroup.addControl(key, new UntypedFormControl(model[key]));
2340
2347
  }
2348
+ this.adapter.setForm(formGroup);
2349
+ this.formGroup.next(formGroup);
2341
2350
  });
2342
2351
  }
2343
2352
  save() {
@@ -2355,7 +2364,7 @@ class EntityEditFormComponent {
2355
2364
  }
2356
2365
  }
2357
2366
  EntityEditFormComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.4", ngImport: i0, type: EntityEditFormComponent, deps: [{ token: i1$5.ActivatedRoute }], target: i0.ɵɵFactoryTarget.Component });
2358
- EntityEditFormComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.4", type: EntityEditFormComponent, selector: "entity-edit-form", inputs: { title: "title", adapter: "adapter" }, viewQueries: [{ propertyName: "generalErrors", first: true, predicate: ["general_errors"], descendants: true }], ngImport: i0, template: "<div class=\"col-md-8\">\n <header class=\"header-page-bg\">\n <h4>{{ title | translate }}</h4>\n </header>\n <div class=\"panel editor-area hero-unit\">\n <form\n class=\"form-horizontal\"\n [formGroup]=\"formGroup | async\"\n novalidate\n autocomplete=\"off\"\n *ngIf=\"formGroup | async\"\n >\n <div class=\"col-md-3\"></div>\n <div class=\"col-md-9\">\n <app-general-errors\n #general_errors\n [form]=\"formGroup | async\"\n ></app-general-errors>\n </div>\n <ng-content></ng-content>\n <entity-edit-buttons-bar\n (save)=\"save()\"\n [valid]=\"\n formGroup.value.valid && formGroup.value.dirty && !saveInProgress\n \"\n >\n </entity-edit-buttons-bar>\n </form>\n </div>\n</div>\n", styles: [""], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: GeneralErrorsComponent, selector: "app-general-errors", inputs: ["form"] }, { kind: "directive", type: i1$4.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1$4.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1$4.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "component", type: EntityEditButtonsBarComponent, selector: "entity-edit-buttons-bar", inputs: ["valid"], outputs: ["save"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "pipe", type: i1$1.TranslatePipe, name: "translate" }] });
2367
+ EntityEditFormComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.4", type: EntityEditFormComponent, selector: "entity-edit-form", inputs: { title: "title", entityId: "entityId", adapter: "adapter" }, viewQueries: [{ propertyName: "generalErrors", first: true, predicate: ["general_errors"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"col-md-8\">\n <header class=\"header-page-bg\">\n <h4>{{ title | translate }}</h4>\n </header>\n <div class=\"panel editor-area hero-unit\">\n <form\n class=\"form-horizontal\"\n [formGroup]=\"formGroup | async\"\n novalidate\n autocomplete=\"off\"\n *ngIf=\"formGroup | async\"\n >\n <div class=\"col-md-3\"></div>\n <div class=\"col-md-9\">\n <app-general-errors\n #general_errors\n [form]=\"formGroup | async\"\n ></app-general-errors>\n </div>\n <ng-content></ng-content>\n <entity-edit-buttons-bar\n (save)=\"save()\"\n [valid]=\"\n formGroup.value.valid && formGroup.value.dirty && !saveInProgress\n \"\n >\n </entity-edit-buttons-bar>\n </form>\n </div>\n</div>\n", styles: [""], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: GeneralErrorsComponent, selector: "app-general-errors", inputs: ["form"] }, { kind: "directive", type: i1$4.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1$4.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1$4.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "component", type: EntityEditButtonsBarComponent, selector: "entity-edit-buttons-bar", inputs: ["valid"], outputs: ["save"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "pipe", type: i1$1.TranslatePipe, name: "translate" }] });
2359
2368
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.4", ngImport: i0, type: EntityEditFormComponent, decorators: [{
2360
2369
  type: Component,
2361
2370
  args: [{ selector: 'entity-edit-form', template: "<div class=\"col-md-8\">\n <header class=\"header-page-bg\">\n <h4>{{ title | translate }}</h4>\n </header>\n <div class=\"panel editor-area hero-unit\">\n <form\n class=\"form-horizontal\"\n [formGroup]=\"formGroup | async\"\n novalidate\n autocomplete=\"off\"\n *ngIf=\"formGroup | async\"\n >\n <div class=\"col-md-3\"></div>\n <div class=\"col-md-9\">\n <app-general-errors\n #general_errors\n [form]=\"formGroup | async\"\n ></app-general-errors>\n </div>\n <ng-content></ng-content>\n <entity-edit-buttons-bar\n (save)=\"save()\"\n [valid]=\"\n formGroup.value.valid && formGroup.value.dirty && !saveInProgress\n \"\n >\n </entity-edit-buttons-bar>\n </form>\n </div>\n</div>\n" }]
@@ -2364,6 +2373,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.4", ngImpor
2364
2373
  args: ['general_errors']
2365
2374
  }], title: [{
2366
2375
  type: Input
2376
+ }], entityId: [{
2377
+ type: Input
2367
2378
  }], adapter: [{
2368
2379
  type: Input
2369
2380
  }] } });