@provoly/hypervisor 1.4.32 → 1.4.33

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.
@@ -3,8 +3,11 @@ import { SubscriptionnerDirective } from '@provoly/dashboard';
3
3
  import { DOMAINS } from '../../model/domains.constant';
4
4
  import equal from 'fast-deep-equal/es6';
5
5
  import { padId } from '../../general/pad-id.function';
6
+ import { ofType } from "@ngrx/effects";
7
+ import { ProcedureActions } from "../../store/procedure/procedure.actions";
8
+ import { delay } from "rxjs";
6
9
  import * as i0 from "@angular/core";
7
- import * as i1 from "@ngrx/store";
10
+ import * as i1 from "@ngrx/effects";
8
11
  import * as i2 from "@angular/forms";
9
12
  import * as i3 from "@provoly/dashboard";
10
13
  import * as i4 from "../../general/procedure-actions/procedure-actions.component";
@@ -17,11 +20,12 @@ export class ProcedureModelDetailComponent extends SubscriptionnerDirective {
17
20
  get modifiedModel() {
18
21
  return { ...this.model, ...(this.modifications ?? {}) };
19
22
  }
20
- constructor(store) {
23
+ constructor(actions$) {
21
24
  super();
22
- this.store = store;
25
+ this.actions$ = actions$;
23
26
  this.username = 'xxx';
24
27
  this.modifications = {};
28
+ this.saved = false;
25
29
  this.errors = [];
26
30
  this.eventErrors = [];
27
31
  this.eventErrorsChange = new EventEmitter();
@@ -30,6 +34,18 @@ export class ProcedureModelDetailComponent extends SubscriptionnerDirective {
30
34
  this.readonly = false;
31
35
  this.readOnlyComment = false;
32
36
  this.padId = padId;
37
+ this.subscriptions.add(this.actions$.pipe(ofType(ProcedureActions.save))
38
+ .subscribe({
39
+ next: result => {
40
+ this.saved = true;
41
+ }
42
+ }));
43
+ this.subscriptions.add(this.actions$.pipe(ofType(ProcedureActions.saveSuccess), delay(1000))
44
+ .subscribe({
45
+ next: result => {
46
+ this.saved = false;
47
+ }
48
+ }));
33
49
  }
34
50
  hasError(prop) {
35
51
  return this.errors.find((err) => err.field === prop) ?? false;
@@ -50,25 +66,27 @@ export class ProcedureModelDetailComponent extends SubscriptionnerDirective {
50
66
  }
51
67
  }
52
68
  modify(prop, $event) {
53
- if (prop === 'name') {
54
- const index = this.errors.findIndex(error => error.field == 'title');
55
- if (index !== -1) {
56
- this.errors.splice(index, 1);
69
+ if (!this.saved) {
70
+ if (prop === 'name') {
71
+ const index = this.errors.findIndex(error => error.field == 'title');
72
+ if (index !== -1) {
73
+ this.errors.splice(index, 1);
74
+ }
57
75
  }
58
- }
59
- // @ts-ignore
60
- const newValue = $event instanceof Event ? $event.target?.value : $event;
61
- if (this.model) {
62
76
  // @ts-ignore
63
- if (this.model[prop] !== newValue) {
64
- // @ts-ignore
65
- this.modifications[prop] = newValue;
66
- this._outputModifications();
67
- }
68
- else {
77
+ const newValue = $event instanceof Event ? $event.target?.value : $event;
78
+ if (this.model) {
69
79
  // @ts-ignore
70
- delete this.modifications[prop];
71
- this._outputModifications();
80
+ if (this.model[prop] !== newValue) {
81
+ // @ts-ignore
82
+ this.modifications[prop] = newValue;
83
+ this._outputModifications();
84
+ }
85
+ else {
86
+ // @ts-ignore
87
+ delete this.modifications[prop];
88
+ this._outputModifications();
89
+ }
72
90
  }
73
91
  }
74
92
  }
@@ -85,13 +103,13 @@ export class ProcedureModelDetailComponent extends SubscriptionnerDirective {
85
103
  }
86
104
  this._outputModifications();
87
105
  }
88
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: ProcedureModelDetailComponent, deps: [{ token: i1.Store }], target: i0.ɵɵFactoryTarget.Component }); }
106
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: ProcedureModelDetailComponent, deps: [{ token: i1.Actions }], target: i0.ɵɵFactoryTarget.Component }); }
89
107
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.6", type: ProcedureModelDetailComponent, selector: "hvy-procedure-model-detail", inputs: { model: "model", username: "username", title: "title", eventErrors: "eventErrors", readonly: "readonly", readOnlyComment: "readOnlyComment", cancelModifications: "cancelModifications" }, outputs: { eventErrorsChange: "eventErrorsChange", modified: "modified" }, usesInheritance: true, ngImport: i0, template: "<div class=\"o-hvy-procedure-detail\">\n <h1>{{ title ?? '@hvy.procedure.detail' | i18n }}</h1>\n <div class=\"o-hvy-procedure-detail__container\">\n <div class=\"o-hvy-procedure-detail__container__scrollable\">\n @if (modifiedModel; as model) {\n <div class=\"o-hvy-procedure-detail__form\">\n <h3>{{ '@hvy.procedure.formTitle' | i18n }}</h3>\n <table>\n <tbody>\n <tr>\n <td>{{ '@hvy.procedure.title' | i18n }}<span class=\"required\">*</span> :</td>\n <td>\n <input\n type=\"text\"\n class=\"a-form-field\"\n [class.-error]=\"hasError('name')\"\n [value]=\"model.name\"\n (change)=\"modify('name', $event)\"\n [maxLength]=\"50\"\n [readonly]=\"readonly\"\n />\n @if (hasError('title')) {\n <span class=\"a-form-field -error\">{{ '@hvy.procedure.alreadyExists' | i18n }}</span>\n }\n </td>\n </tr>\n @if (model.id > 0) {\n <tr>\n <td>{{ '@hvy.event.log.event.id' | i18n }}<span class=\"required\">*</span> :</td>\n <td>\n <input type=\"text\" class=\"a-form-field\" [value]=\"padId.fn(model.id)\" readonly />\n </td>\n </tr>\n }\n <tr>\n <td>{{ '@hvy.procedure.description' | i18n }}<span class=\"required\">*</span> :</td>\n <td>\n <textarea\n [ngModel]=\"model.description\"\n class=\"a-form-field\"\n [class.-error]=\"hasError('description')\"\n (ngModelChange)=\"modify('description', $event)\"\n [maxLength]=\"256\"\n [readonly]=\"readonly\"\n ></textarea>\n </td>\n </tr>\n <tr>\n <td>{{ '@hvy.event.domain.name' | i18n }}<span class=\"required\">*</span> :</td>\n <td>\n <pry-select\n [items]=\"DOMAINS\"\n [ngModel]=\"model.domain\"\n i18nPrefix=\"@hvy.event.domain.\"\n [class.-error]=\"hasError('domain')\"\n (ngModelChange)=\"modify('domain', $event)\"\n [disabled]=\"readonly\"\n ></pry-select>\n </td>\n </tr>\n <tr>\n <td>{{ '@hvy.procedure.creator' | i18n }}<span class=\"required\">*</span> :</td>\n <td>\n <input type=\"text\" class=\"a-form-field\" [value]=\"model.creator\" readonly />\n </td>\n </tr>\n <tr>\n <td>{{ '@hvy.event.creationDate' | i18n }}<span class=\"required\">*</span> :</td>\n <td>\n <input\n type=\"datetime-local\"\n class=\"a-form-field\"\n [value]=\"model.creationDate | forDateTimeLocal\"\n readonly\n />\n </td>\n </tr>\n <tr>\n <td>{{ '@hvy.event.lastModificationDate' | i18n }}<span class=\"required\">*</span> :</td>\n <td>\n <input\n type=\"datetime-local\"\n class=\"a-form-field\"\n [value]=\"model.lastModificationDate | forDateTimeLocal\"\n readonly\n />\n </td>\n </tr>\n </tbody>\n </table>\n </div>\n <div class=\"o-hvy-procedure-detail__actions\">\n <h3>{{ '@hvy.procedure.actions' | i18n }} ({{ model.actions?.length }})</h3>\n <hvy-procedure-actions\n [actions]=\"model.actions\"\n (modified)=\"updateActions($event)\"\n [readonly]=\"readonly\"\n [readOnlyComment]=\"readOnlyComment\"\n mode=\"model\"\n [enableEditActions]=\"true\"\n ></hvy-procedure-actions>\n </div>\n }\n </div>\n </div>\n</div>\n", dependencies: [{ kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i3.PrySelectComponent, selector: "pry-select", inputs: ["items", "clearable", "multiple", "closeOnSelect", "placeholder", "isForm", "required", "name", "autocomplete", "alwaysShowAutosuggestedValues", "externalAutocompleteService", "bindValue", "bindLabel", "iconSize", "bindIcon", "template", "i18nPrefix", "bindClasses", "loading", "elementRef"], outputs: ["searched", "cleared", "clicked", "pressedEnter"] }, { kind: "component", type: i4.ProcedureActionsComponent, selector: "hvy-procedure-actions", inputs: ["mode", "me", "readonly", "readOnlyComment", "enableEditActions", "events", "actions"], outputs: ["modified", "commented"] }, { kind: "pipe", type: i3.I18nPipe, name: "i18n" }, { kind: "pipe", type: i5.ForDatetimeLocalPipe, name: "forDateTimeLocal" }] }); }
90
108
  }
91
109
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: ProcedureModelDetailComponent, decorators: [{
92
110
  type: Component,
93
111
  args: [{ selector: 'hvy-procedure-model-detail', template: "<div class=\"o-hvy-procedure-detail\">\n <h1>{{ title ?? '@hvy.procedure.detail' | i18n }}</h1>\n <div class=\"o-hvy-procedure-detail__container\">\n <div class=\"o-hvy-procedure-detail__container__scrollable\">\n @if (modifiedModel; as model) {\n <div class=\"o-hvy-procedure-detail__form\">\n <h3>{{ '@hvy.procedure.formTitle' | i18n }}</h3>\n <table>\n <tbody>\n <tr>\n <td>{{ '@hvy.procedure.title' | i18n }}<span class=\"required\">*</span> :</td>\n <td>\n <input\n type=\"text\"\n class=\"a-form-field\"\n [class.-error]=\"hasError('name')\"\n [value]=\"model.name\"\n (change)=\"modify('name', $event)\"\n [maxLength]=\"50\"\n [readonly]=\"readonly\"\n />\n @if (hasError('title')) {\n <span class=\"a-form-field -error\">{{ '@hvy.procedure.alreadyExists' | i18n }}</span>\n }\n </td>\n </tr>\n @if (model.id > 0) {\n <tr>\n <td>{{ '@hvy.event.log.event.id' | i18n }}<span class=\"required\">*</span> :</td>\n <td>\n <input type=\"text\" class=\"a-form-field\" [value]=\"padId.fn(model.id)\" readonly />\n </td>\n </tr>\n }\n <tr>\n <td>{{ '@hvy.procedure.description' | i18n }}<span class=\"required\">*</span> :</td>\n <td>\n <textarea\n [ngModel]=\"model.description\"\n class=\"a-form-field\"\n [class.-error]=\"hasError('description')\"\n (ngModelChange)=\"modify('description', $event)\"\n [maxLength]=\"256\"\n [readonly]=\"readonly\"\n ></textarea>\n </td>\n </tr>\n <tr>\n <td>{{ '@hvy.event.domain.name' | i18n }}<span class=\"required\">*</span> :</td>\n <td>\n <pry-select\n [items]=\"DOMAINS\"\n [ngModel]=\"model.domain\"\n i18nPrefix=\"@hvy.event.domain.\"\n [class.-error]=\"hasError('domain')\"\n (ngModelChange)=\"modify('domain', $event)\"\n [disabled]=\"readonly\"\n ></pry-select>\n </td>\n </tr>\n <tr>\n <td>{{ '@hvy.procedure.creator' | i18n }}<span class=\"required\">*</span> :</td>\n <td>\n <input type=\"text\" class=\"a-form-field\" [value]=\"model.creator\" readonly />\n </td>\n </tr>\n <tr>\n <td>{{ '@hvy.event.creationDate' | i18n }}<span class=\"required\">*</span> :</td>\n <td>\n <input\n type=\"datetime-local\"\n class=\"a-form-field\"\n [value]=\"model.creationDate | forDateTimeLocal\"\n readonly\n />\n </td>\n </tr>\n <tr>\n <td>{{ '@hvy.event.lastModificationDate' | i18n }}<span class=\"required\">*</span> :</td>\n <td>\n <input\n type=\"datetime-local\"\n class=\"a-form-field\"\n [value]=\"model.lastModificationDate | forDateTimeLocal\"\n readonly\n />\n </td>\n </tr>\n </tbody>\n </table>\n </div>\n <div class=\"o-hvy-procedure-detail__actions\">\n <h3>{{ '@hvy.procedure.actions' | i18n }} ({{ model.actions?.length }})</h3>\n <hvy-procedure-actions\n [actions]=\"model.actions\"\n (modified)=\"updateActions($event)\"\n [readonly]=\"readonly\"\n [readOnlyComment]=\"readOnlyComment\"\n mode=\"model\"\n [enableEditActions]=\"true\"\n ></hvy-procedure-actions>\n </div>\n }\n </div>\n </div>\n</div>\n" }]
94
- }], ctorParameters: () => [{ type: i1.Store }], propDecorators: { model: [{
112
+ }], ctorParameters: () => [{ type: i1.Actions }], propDecorators: { model: [{
95
113
  type: Input
96
114
  }], username: [{
97
115
  type: Input
@@ -110,4 +128,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImpor
110
128
  }], cancelModifications: [{
111
129
  type: Input
112
130
  }] } });
113
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"procedure-model-detail.component.js","sourceRoot":"","sources":["../../../../../../../../projects/provoly/hypervisor/src/lib/procedure/model-detail/procedure-model-detail.component.ts","../../../../../../../../projects/provoly/hypervisor/src/lib/procedure/model-detail/procedure-model-detail.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\nimport { SubscriptionnerDirective } from '@provoly/dashboard';\nimport { HypProcedureModel } from '../../model/procedure/hyp-procedure-model.interface';\nimport { DOMAINS } from '../../model/domains.constant';\nimport { Store } from '@ngrx/store';\nimport equal from 'fast-deep-equal/es6';\nimport { HypAction } from '../../model/procedure/hyp-action.interface';\nimport { padId } from '../../general/pad-id.function';\n\n@Component({\n  selector: 'hvy-procedure-model-detail',\n  templateUrl: './procedure-model-detail.component.html'\n})\nexport class ProcedureModelDetailComponent extends SubscriptionnerDirective {\n  @Input() model?: HypProcedureModel;\n  @Input() username: string = 'xxx';\n  modifications: Partial<HypProcedureModel> = {};\n  @Input() title?: string;\n  errors: { field: string; code: string }[] = [];\n  @Input() eventErrors  : { field: string; code: string }[] = [];\n  @Output() eventErrorsChange = new EventEmitter<{ field: string; code: string }[]>();\n  @Output() modified = new EventEmitter<[Partial<HypProcedureModel>, HypProcedureModel]>();\n  protected readonly DOMAINS = DOMAINS.values;\n  @Input() readonly = false;\n  @Input() readOnlyComment = false;\n\n  @Input() set cancelModifications(evt: any) {\n    this.modifications = {};\n    this._outputModifications();\n  }\n\n  get modifiedModel() {\n    return { ...this.model, ...(this.modifications ?? {}) } as HypProcedureModel;\n  }\n\n  constructor(private store: Store) {\n    super();\n  }\n\n  hasError(prop: string) {\n    return this.errors.find((err) => err.field === prop) ?? false;\n  }\n\n  validate(model: HypProcedureModel) {\n    if (!!model) {\n      this.errors = [];\n      if (!model.name || model.name.length === 0) {\n        this.errors.push({ field: 'name', code: 'required' });\n      }\n      if (!model.domain || model.domain.length === 0) {\n        this.errors.push({ field: 'domain', code: 'required' });\n      }\n      if (!model.description || model.description.length === 0) {\n        this.errors.push({ field: 'description', code: 'required' });\n      }\n      this.eventErrorsChange.next(this.errors);\n    }\n  }\n\n  modify(prop: string, $event: Event) {\n    if(prop === 'name'){\n      const index = this.errors.findIndex(error => error.field == 'title');\n      if(index !== -1){\n        this.errors.splice(index, 1);\n      }\n    }\n    // @ts-ignore\n    const newValue = $event instanceof Event ? $event.target?.value : $event;\n\n    if (this.model) {\n      // @ts-ignore\n      if (this.model[prop] !== newValue) {\n        // @ts-ignore\n        this.modifications[prop] = newValue;\n\n        this._outputModifications();\n      } else {\n        // @ts-ignore\n        delete this.modifications[prop];\n        this._outputModifications();\n      }\n    }\n  }\n\n  private _outputModifications() {\n    this.validate(this.modifiedModel);\n    this.modified.next([this.modifications, this.modifiedModel]);\n  }\n\n  updateActions($event: HypAction[]) {\n    if (equal($event, this.model?.actions)) {\n      delete this.modifications.actions;\n    } else {\n      this.modifications.actions = $event;\n    }\n    this._outputModifications();\n  }\n\n  protected readonly padId = padId;\n}\n","<div class=\"o-hvy-procedure-detail\">\n  <h1>{{ title ?? '@hvy.procedure.detail' | i18n }}</h1>\n  <div class=\"o-hvy-procedure-detail__container\">\n    <div class=\"o-hvy-procedure-detail__container__scrollable\">\n      @if (modifiedModel; as model) {\n        <div class=\"o-hvy-procedure-detail__form\">\n          <h3>{{ '@hvy.procedure.formTitle' | i18n }}</h3>\n          <table>\n            <tbody>\n              <tr>\n                <td>{{ '@hvy.procedure.title' | i18n }}<span class=\"required\">*</span> :</td>\n                <td>\n                  <input\n                    type=\"text\"\n                    class=\"a-form-field\"\n                    [class.-error]=\"hasError('name')\"\n                    [value]=\"model.name\"\n                    (change)=\"modify('name', $event)\"\n                    [maxLength]=\"50\"\n                    [readonly]=\"readonly\"\n                  />\n                  @if (hasError('title')) {\n                    <span class=\"a-form-field -error\">{{ '@hvy.procedure.alreadyExists' | i18n }}</span>\n                  }\n                </td>\n              </tr>\n                @if (model.id > 0) {\n                  <tr>\n                    <td>{{ '@hvy.event.log.event.id' | i18n }}<span class=\"required\">*</span> :</td>\n                    <td>\n                      <input type=\"text\" class=\"a-form-field\" [value]=\"padId.fn(model.id)\" readonly />\n                    </td>\n                  </tr>\n                }\n              <tr>\n                <td>{{ '@hvy.procedure.description' | i18n }}<span class=\"required\">*</span> :</td>\n                <td>\n                  <textarea\n                    [ngModel]=\"model.description\"\n                    class=\"a-form-field\"\n                    [class.-error]=\"hasError('description')\"\n                    (ngModelChange)=\"modify('description', $event)\"\n                    [maxLength]=\"256\"\n                    [readonly]=\"readonly\"\n                  ></textarea>\n                </td>\n              </tr>\n              <tr>\n                <td>{{ '@hvy.event.domain.name' | i18n }}<span class=\"required\">*</span> :</td>\n                <td>\n                  <pry-select\n                    [items]=\"DOMAINS\"\n                    [ngModel]=\"model.domain\"\n                    i18nPrefix=\"@hvy.event.domain.\"\n                    [class.-error]=\"hasError('domain')\"\n                    (ngModelChange)=\"modify('domain', $event)\"\n                    [disabled]=\"readonly\"\n                  ></pry-select>\n                </td>\n              </tr>\n              <tr>\n                <td>{{ '@hvy.procedure.creator' | i18n }}<span class=\"required\">*</span> :</td>\n                <td>\n                  <input type=\"text\" class=\"a-form-field\" [value]=\"model.creator\" readonly />\n                </td>\n              </tr>\n                <tr>\n                  <td>{{ '@hvy.event.creationDate' | i18n }}<span class=\"required\">*</span> :</td>\n                  <td>\n                    <input\n                      type=\"datetime-local\"\n                      class=\"a-form-field\"\n                      [value]=\"model.creationDate | forDateTimeLocal\"\n                      readonly\n                    />\n                  </td>\n                </tr>\n                <tr>\n                  <td>{{ '@hvy.event.lastModificationDate' | i18n }}<span class=\"required\">*</span> :</td>\n                  <td>\n                    <input\n                      type=\"datetime-local\"\n                      class=\"a-form-field\"\n                      [value]=\"model.lastModificationDate | forDateTimeLocal\"\n                      readonly\n                    />\n                  </td>\n                </tr>\n            </tbody>\n          </table>\n        </div>\n        <div class=\"o-hvy-procedure-detail__actions\">\n          <h3>{{ '@hvy.procedure.actions' | i18n }} ({{ model.actions?.length }})</h3>\n          <hvy-procedure-actions\n            [actions]=\"model.actions\"\n            (modified)=\"updateActions($event)\"\n            [readonly]=\"readonly\"\n            [readOnlyComment]=\"readOnlyComment\"\n            mode=\"model\"\n            [enableEditActions]=\"true\"\n          ></hvy-procedure-actions>\n        </div>\n      }\n    </div>\n  </div>\n</div>\n"]}
131
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"procedure-model-detail.component.js","sourceRoot":"","sources":["../../../../../../../../projects/provoly/hypervisor/src/lib/procedure/model-detail/procedure-model-detail.component.ts","../../../../../../../../projects/provoly/hypervisor/src/lib/procedure/model-detail/procedure-model-detail.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\nimport { SubscriptionnerDirective } from '@provoly/dashboard';\nimport { HypProcedureModel } from '../../model/procedure/hyp-procedure-model.interface';\nimport { DOMAINS } from '../../model/domains.constant';\nimport { Store } from '@ngrx/store';\nimport equal from 'fast-deep-equal/es6';\nimport { HypAction } from '../../model/procedure/hyp-action.interface';\nimport { padId } from '../../general/pad-id.function';\nimport {Actions, ofType} from \"@ngrx/effects\";\nimport {ProcedureActions} from \"../../store/procedure/procedure.actions\";\nimport {delay} from \"rxjs\";\n\n@Component({\n  selector: 'hvy-procedure-model-detail',\n  templateUrl: './procedure-model-detail.component.html'\n})\nexport class ProcedureModelDetailComponent extends SubscriptionnerDirective {\n  @Input() model?: HypProcedureModel;\n  @Input() username: string = 'xxx';\n  modifications: Partial<HypProcedureModel> = {};\n  @Input() title?: string;\n  saved = false;\n  errors: { field: string; code: string }[] = [];\n  @Input() eventErrors  : { field: string; code: string }[] = [];\n  @Output() eventErrorsChange = new EventEmitter<{ field: string; code: string }[]>();\n  @Output() modified = new EventEmitter<[Partial<HypProcedureModel>, HypProcedureModel]>();\n  protected readonly DOMAINS = DOMAINS.values;\n  @Input() readonly = false;\n  @Input() readOnlyComment = false;\n\n  @Input() set cancelModifications(evt: any) {\n    this.modifications = {};\n    this._outputModifications();\n  }\n\n  get modifiedModel() {\n    return { ...this.model, ...(this.modifications ?? {}) } as HypProcedureModel;\n  }\n\n  constructor(private actions$: Actions) {\n    super();\n    this.subscriptions.add(\n      this.actions$.pipe(\n        ofType(ProcedureActions.save)\n      )\n        .subscribe({\n          next: result => {\n            this.saved = true;\n          }\n        })\n    )\n    this.subscriptions.add(\n      this.actions$.pipe(\n        ofType(ProcedureActions.saveSuccess),\n        delay(1000),\n      )\n        .subscribe({\n          next: result => {\n            this.saved = false;\n          }\n        })\n    )\n  }\n\n  hasError(prop: string) {\n    return this.errors.find((err) => err.field === prop) ?? false;\n  }\n\n  validate(model: HypProcedureModel) {\n    if (!!model) {\n      this.errors = [];\n      if (!model.name || model.name.length === 0) {\n        this.errors.push({ field: 'name', code: 'required' });\n      }\n      if (!model.domain || model.domain.length === 0) {\n        this.errors.push({ field: 'domain', code: 'required' });\n      }\n      if (!model.description || model.description.length === 0) {\n        this.errors.push({ field: 'description', code: 'required' });\n      }\n      this.eventErrorsChange.next(this.errors);\n    }\n  }\n\n  modify(prop: string, $event: Event) {\n    if(!this.saved){\n      if(prop === 'name'){\n        const index = this.errors.findIndex(error => error.field == 'title');\n        if(index !== -1){\n          this.errors.splice(index, 1);\n        }\n      }\n      // @ts-ignore\n      const newValue = $event instanceof Event ? $event.target?.value : $event;\n\n      if (this.model) {\n        // @ts-ignore\n        if (this.model[prop] !== newValue) {\n          // @ts-ignore\n          this.modifications[prop] = newValue;\n\n          this._outputModifications();\n        } else {\n          // @ts-ignore\n          delete this.modifications[prop];\n          this._outputModifications();\n        }\n      }\n    }\n\n  }\n\n  private _outputModifications() {\n    this.validate(this.modifiedModel);\n    this.modified.next([this.modifications, this.modifiedModel]);\n  }\n\n  updateActions($event: HypAction[]) {\n    if (equal($event, this.model?.actions)) {\n      delete this.modifications.actions;\n    } else {\n      this.modifications.actions = $event;\n    }\n    this._outputModifications();\n  }\n\n  protected readonly padId = padId;\n}\n","<div class=\"o-hvy-procedure-detail\">\n  <h1>{{ title ?? '@hvy.procedure.detail' | i18n }}</h1>\n  <div class=\"o-hvy-procedure-detail__container\">\n    <div class=\"o-hvy-procedure-detail__container__scrollable\">\n      @if (modifiedModel; as model) {\n        <div class=\"o-hvy-procedure-detail__form\">\n          <h3>{{ '@hvy.procedure.formTitle' | i18n }}</h3>\n          <table>\n            <tbody>\n              <tr>\n                <td>{{ '@hvy.procedure.title' | i18n }}<span class=\"required\">*</span> :</td>\n                <td>\n                  <input\n                    type=\"text\"\n                    class=\"a-form-field\"\n                    [class.-error]=\"hasError('name')\"\n                    [value]=\"model.name\"\n                    (change)=\"modify('name', $event)\"\n                    [maxLength]=\"50\"\n                    [readonly]=\"readonly\"\n                  />\n                  @if (hasError('title')) {\n                    <span class=\"a-form-field -error\">{{ '@hvy.procedure.alreadyExists' | i18n }}</span>\n                  }\n                </td>\n              </tr>\n                @if (model.id > 0) {\n                  <tr>\n                    <td>{{ '@hvy.event.log.event.id' | i18n }}<span class=\"required\">*</span> :</td>\n                    <td>\n                      <input type=\"text\" class=\"a-form-field\" [value]=\"padId.fn(model.id)\" readonly />\n                    </td>\n                  </tr>\n                }\n              <tr>\n                <td>{{ '@hvy.procedure.description' | i18n }}<span class=\"required\">*</span> :</td>\n                <td>\n                  <textarea\n                    [ngModel]=\"model.description\"\n                    class=\"a-form-field\"\n                    [class.-error]=\"hasError('description')\"\n                    (ngModelChange)=\"modify('description', $event)\"\n                    [maxLength]=\"256\"\n                    [readonly]=\"readonly\"\n                  ></textarea>\n                </td>\n              </tr>\n              <tr>\n                <td>{{ '@hvy.event.domain.name' | i18n }}<span class=\"required\">*</span> :</td>\n                <td>\n                  <pry-select\n                    [items]=\"DOMAINS\"\n                    [ngModel]=\"model.domain\"\n                    i18nPrefix=\"@hvy.event.domain.\"\n                    [class.-error]=\"hasError('domain')\"\n                    (ngModelChange)=\"modify('domain', $event)\"\n                    [disabled]=\"readonly\"\n                  ></pry-select>\n                </td>\n              </tr>\n              <tr>\n                <td>{{ '@hvy.procedure.creator' | i18n }}<span class=\"required\">*</span> :</td>\n                <td>\n                  <input type=\"text\" class=\"a-form-field\" [value]=\"model.creator\" readonly />\n                </td>\n              </tr>\n                <tr>\n                  <td>{{ '@hvy.event.creationDate' | i18n }}<span class=\"required\">*</span> :</td>\n                  <td>\n                    <input\n                      type=\"datetime-local\"\n                      class=\"a-form-field\"\n                      [value]=\"model.creationDate | forDateTimeLocal\"\n                      readonly\n                    />\n                  </td>\n                </tr>\n                <tr>\n                  <td>{{ '@hvy.event.lastModificationDate' | i18n }}<span class=\"required\">*</span> :</td>\n                  <td>\n                    <input\n                      type=\"datetime-local\"\n                      class=\"a-form-field\"\n                      [value]=\"model.lastModificationDate | forDateTimeLocal\"\n                      readonly\n                    />\n                  </td>\n                </tr>\n            </tbody>\n          </table>\n        </div>\n        <div class=\"o-hvy-procedure-detail__actions\">\n          <h3>{{ '@hvy.procedure.actions' | i18n }} ({{ model.actions?.length }})</h3>\n          <hvy-procedure-actions\n            [actions]=\"model.actions\"\n            (modified)=\"updateActions($event)\"\n            [readonly]=\"readonly\"\n            [readOnlyComment]=\"readOnlyComment\"\n            mode=\"model\"\n            [enableEditActions]=\"true\"\n          ></hvy-procedure-actions>\n        </div>\n      }\n    </div>\n  </div>\n</div>\n"]}
@@ -2866,11 +2866,12 @@ class ProcedureModelDetailComponent extends SubscriptionnerDirective {
2866
2866
  get modifiedModel() {
2867
2867
  return { ...this.model, ...(this.modifications ?? {}) };
2868
2868
  }
2869
- constructor(store) {
2869
+ constructor(actions$) {
2870
2870
  super();
2871
- this.store = store;
2871
+ this.actions$ = actions$;
2872
2872
  this.username = 'xxx';
2873
2873
  this.modifications = {};
2874
+ this.saved = false;
2874
2875
  this.errors = [];
2875
2876
  this.eventErrors = [];
2876
2877
  this.eventErrorsChange = new EventEmitter();
@@ -2879,6 +2880,18 @@ class ProcedureModelDetailComponent extends SubscriptionnerDirective {
2879
2880
  this.readonly = false;
2880
2881
  this.readOnlyComment = false;
2881
2882
  this.padId = padId;
2883
+ this.subscriptions.add(this.actions$.pipe(ofType(ProcedureActions.save))
2884
+ .subscribe({
2885
+ next: result => {
2886
+ this.saved = true;
2887
+ }
2888
+ }));
2889
+ this.subscriptions.add(this.actions$.pipe(ofType(ProcedureActions.saveSuccess), delay(1000))
2890
+ .subscribe({
2891
+ next: result => {
2892
+ this.saved = false;
2893
+ }
2894
+ }));
2882
2895
  }
2883
2896
  hasError(prop) {
2884
2897
  return this.errors.find((err) => err.field === prop) ?? false;
@@ -2899,25 +2912,27 @@ class ProcedureModelDetailComponent extends SubscriptionnerDirective {
2899
2912
  }
2900
2913
  }
2901
2914
  modify(prop, $event) {
2902
- if (prop === 'name') {
2903
- const index = this.errors.findIndex(error => error.field == 'title');
2904
- if (index !== -1) {
2905
- this.errors.splice(index, 1);
2915
+ if (!this.saved) {
2916
+ if (prop === 'name') {
2917
+ const index = this.errors.findIndex(error => error.field == 'title');
2918
+ if (index !== -1) {
2919
+ this.errors.splice(index, 1);
2920
+ }
2906
2921
  }
2907
- }
2908
- // @ts-ignore
2909
- const newValue = $event instanceof Event ? $event.target?.value : $event;
2910
- if (this.model) {
2911
2922
  // @ts-ignore
2912
- if (this.model[prop] !== newValue) {
2923
+ const newValue = $event instanceof Event ? $event.target?.value : $event;
2924
+ if (this.model) {
2913
2925
  // @ts-ignore
2914
- this.modifications[prop] = newValue;
2915
- this._outputModifications();
2916
- }
2917
- else {
2918
- // @ts-ignore
2919
- delete this.modifications[prop];
2920
- this._outputModifications();
2926
+ if (this.model[prop] !== newValue) {
2927
+ // @ts-ignore
2928
+ this.modifications[prop] = newValue;
2929
+ this._outputModifications();
2930
+ }
2931
+ else {
2932
+ // @ts-ignore
2933
+ delete this.modifications[prop];
2934
+ this._outputModifications();
2935
+ }
2921
2936
  }
2922
2937
  }
2923
2938
  }
@@ -2934,13 +2949,13 @@ class ProcedureModelDetailComponent extends SubscriptionnerDirective {
2934
2949
  }
2935
2950
  this._outputModifications();
2936
2951
  }
2937
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: ProcedureModelDetailComponent, deps: [{ token: i1$1.Store }], target: i0.ɵɵFactoryTarget.Component }); }
2952
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: ProcedureModelDetailComponent, deps: [{ token: i1$5.Actions }], target: i0.ɵɵFactoryTarget.Component }); }
2938
2953
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.6", type: ProcedureModelDetailComponent, selector: "hvy-procedure-model-detail", inputs: { model: "model", username: "username", title: "title", eventErrors: "eventErrors", readonly: "readonly", readOnlyComment: "readOnlyComment", cancelModifications: "cancelModifications" }, outputs: { eventErrorsChange: "eventErrorsChange", modified: "modified" }, usesInheritance: true, ngImport: i0, template: "<div class=\"o-hvy-procedure-detail\">\n <h1>{{ title ?? '@hvy.procedure.detail' | i18n }}</h1>\n <div class=\"o-hvy-procedure-detail__container\">\n <div class=\"o-hvy-procedure-detail__container__scrollable\">\n @if (modifiedModel; as model) {\n <div class=\"o-hvy-procedure-detail__form\">\n <h3>{{ '@hvy.procedure.formTitle' | i18n }}</h3>\n <table>\n <tbody>\n <tr>\n <td>{{ '@hvy.procedure.title' | i18n }}<span class=\"required\">*</span> :</td>\n <td>\n <input\n type=\"text\"\n class=\"a-form-field\"\n [class.-error]=\"hasError('name')\"\n [value]=\"model.name\"\n (change)=\"modify('name', $event)\"\n [maxLength]=\"50\"\n [readonly]=\"readonly\"\n />\n @if (hasError('title')) {\n <span class=\"a-form-field -error\">{{ '@hvy.procedure.alreadyExists' | i18n }}</span>\n }\n </td>\n </tr>\n @if (model.id > 0) {\n <tr>\n <td>{{ '@hvy.event.log.event.id' | i18n }}<span class=\"required\">*</span> :</td>\n <td>\n <input type=\"text\" class=\"a-form-field\" [value]=\"padId.fn(model.id)\" readonly />\n </td>\n </tr>\n }\n <tr>\n <td>{{ '@hvy.procedure.description' | i18n }}<span class=\"required\">*</span> :</td>\n <td>\n <textarea\n [ngModel]=\"model.description\"\n class=\"a-form-field\"\n [class.-error]=\"hasError('description')\"\n (ngModelChange)=\"modify('description', $event)\"\n [maxLength]=\"256\"\n [readonly]=\"readonly\"\n ></textarea>\n </td>\n </tr>\n <tr>\n <td>{{ '@hvy.event.domain.name' | i18n }}<span class=\"required\">*</span> :</td>\n <td>\n <pry-select\n [items]=\"DOMAINS\"\n [ngModel]=\"model.domain\"\n i18nPrefix=\"@hvy.event.domain.\"\n [class.-error]=\"hasError('domain')\"\n (ngModelChange)=\"modify('domain', $event)\"\n [disabled]=\"readonly\"\n ></pry-select>\n </td>\n </tr>\n <tr>\n <td>{{ '@hvy.procedure.creator' | i18n }}<span class=\"required\">*</span> :</td>\n <td>\n <input type=\"text\" class=\"a-form-field\" [value]=\"model.creator\" readonly />\n </td>\n </tr>\n <tr>\n <td>{{ '@hvy.event.creationDate' | i18n }}<span class=\"required\">*</span> :</td>\n <td>\n <input\n type=\"datetime-local\"\n class=\"a-form-field\"\n [value]=\"model.creationDate | forDateTimeLocal\"\n readonly\n />\n </td>\n </tr>\n <tr>\n <td>{{ '@hvy.event.lastModificationDate' | i18n }}<span class=\"required\">*</span> :</td>\n <td>\n <input\n type=\"datetime-local\"\n class=\"a-form-field\"\n [value]=\"model.lastModificationDate | forDateTimeLocal\"\n readonly\n />\n </td>\n </tr>\n </tbody>\n </table>\n </div>\n <div class=\"o-hvy-procedure-detail__actions\">\n <h3>{{ '@hvy.procedure.actions' | i18n }} ({{ model.actions?.length }})</h3>\n <hvy-procedure-actions\n [actions]=\"model.actions\"\n (modified)=\"updateActions($event)\"\n [readonly]=\"readonly\"\n [readOnlyComment]=\"readOnlyComment\"\n mode=\"model\"\n [enableEditActions]=\"true\"\n ></hvy-procedure-actions>\n </div>\n }\n </div>\n </div>\n</div>\n", dependencies: [{ kind: "directive", type: i1$4.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1$4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1$4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i1$3.PrySelectComponent, selector: "pry-select", inputs: ["items", "clearable", "multiple", "closeOnSelect", "placeholder", "isForm", "required", "name", "autocomplete", "alwaysShowAutosuggestedValues", "externalAutocompleteService", "bindValue", "bindLabel", "iconSize", "bindIcon", "template", "i18nPrefix", "bindClasses", "loading", "elementRef"], outputs: ["searched", "cleared", "clicked", "pressedEnter"] }, { kind: "component", type: ProcedureActionsComponent, selector: "hvy-procedure-actions", inputs: ["mode", "me", "readonly", "readOnlyComment", "enableEditActions", "events", "actions"], outputs: ["modified", "commented"] }, { kind: "pipe", type: i1$3.I18nPipe, name: "i18n" }, { kind: "pipe", type: ForDatetimeLocalPipe, name: "forDateTimeLocal" }] }); }
2939
2954
  }
2940
2955
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: ProcedureModelDetailComponent, decorators: [{
2941
2956
  type: Component,
2942
2957
  args: [{ selector: 'hvy-procedure-model-detail', template: "<div class=\"o-hvy-procedure-detail\">\n <h1>{{ title ?? '@hvy.procedure.detail' | i18n }}</h1>\n <div class=\"o-hvy-procedure-detail__container\">\n <div class=\"o-hvy-procedure-detail__container__scrollable\">\n @if (modifiedModel; as model) {\n <div class=\"o-hvy-procedure-detail__form\">\n <h3>{{ '@hvy.procedure.formTitle' | i18n }}</h3>\n <table>\n <tbody>\n <tr>\n <td>{{ '@hvy.procedure.title' | i18n }}<span class=\"required\">*</span> :</td>\n <td>\n <input\n type=\"text\"\n class=\"a-form-field\"\n [class.-error]=\"hasError('name')\"\n [value]=\"model.name\"\n (change)=\"modify('name', $event)\"\n [maxLength]=\"50\"\n [readonly]=\"readonly\"\n />\n @if (hasError('title')) {\n <span class=\"a-form-field -error\">{{ '@hvy.procedure.alreadyExists' | i18n }}</span>\n }\n </td>\n </tr>\n @if (model.id > 0) {\n <tr>\n <td>{{ '@hvy.event.log.event.id' | i18n }}<span class=\"required\">*</span> :</td>\n <td>\n <input type=\"text\" class=\"a-form-field\" [value]=\"padId.fn(model.id)\" readonly />\n </td>\n </tr>\n }\n <tr>\n <td>{{ '@hvy.procedure.description' | i18n }}<span class=\"required\">*</span> :</td>\n <td>\n <textarea\n [ngModel]=\"model.description\"\n class=\"a-form-field\"\n [class.-error]=\"hasError('description')\"\n (ngModelChange)=\"modify('description', $event)\"\n [maxLength]=\"256\"\n [readonly]=\"readonly\"\n ></textarea>\n </td>\n </tr>\n <tr>\n <td>{{ '@hvy.event.domain.name' | i18n }}<span class=\"required\">*</span> :</td>\n <td>\n <pry-select\n [items]=\"DOMAINS\"\n [ngModel]=\"model.domain\"\n i18nPrefix=\"@hvy.event.domain.\"\n [class.-error]=\"hasError('domain')\"\n (ngModelChange)=\"modify('domain', $event)\"\n [disabled]=\"readonly\"\n ></pry-select>\n </td>\n </tr>\n <tr>\n <td>{{ '@hvy.procedure.creator' | i18n }}<span class=\"required\">*</span> :</td>\n <td>\n <input type=\"text\" class=\"a-form-field\" [value]=\"model.creator\" readonly />\n </td>\n </tr>\n <tr>\n <td>{{ '@hvy.event.creationDate' | i18n }}<span class=\"required\">*</span> :</td>\n <td>\n <input\n type=\"datetime-local\"\n class=\"a-form-field\"\n [value]=\"model.creationDate | forDateTimeLocal\"\n readonly\n />\n </td>\n </tr>\n <tr>\n <td>{{ '@hvy.event.lastModificationDate' | i18n }}<span class=\"required\">*</span> :</td>\n <td>\n <input\n type=\"datetime-local\"\n class=\"a-form-field\"\n [value]=\"model.lastModificationDate | forDateTimeLocal\"\n readonly\n />\n </td>\n </tr>\n </tbody>\n </table>\n </div>\n <div class=\"o-hvy-procedure-detail__actions\">\n <h3>{{ '@hvy.procedure.actions' | i18n }} ({{ model.actions?.length }})</h3>\n <hvy-procedure-actions\n [actions]=\"model.actions\"\n (modified)=\"updateActions($event)\"\n [readonly]=\"readonly\"\n [readOnlyComment]=\"readOnlyComment\"\n mode=\"model\"\n [enableEditActions]=\"true\"\n ></hvy-procedure-actions>\n </div>\n }\n </div>\n </div>\n</div>\n" }]
2943
- }], ctorParameters: () => [{ type: i1$1.Store }], propDecorators: { model: [{
2958
+ }], ctorParameters: () => [{ type: i1$5.Actions }], propDecorators: { model: [{
2944
2959
  type: Input
2945
2960
  }], username: [{
2946
2961
  type: Input