@provoly/hypervisor 1.4.6 → 1.4.7-7.2
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/esm2022/src/lib/auth/hypervisor-roles.contant.mjs +1 -1
- package/esm2022/src/lib/event/detail/add-event/add-event.component.mjs +1 -1
- package/esm2022/src/lib/event/detail/event-detail.component.mjs +297 -63
- package/esm2022/src/lib/event/detail/event-details-tooltip.component.mjs +12 -7
- package/esm2022/src/lib/event/filters/date/date-filter.component.mjs +7 -3
- package/esm2022/src/lib/event/filters/on/click/event-filters.component.mjs +10 -3
- package/esm2022/src/lib/event/filters/text/text-filter.component.mjs +3 -3
- package/esm2022/src/lib/event/list/event-list.component.mjs +8 -5
- package/esm2022/src/lib/event/procedure-association-modal/procedure-association-modal.component.mjs +37 -10
- package/esm2022/src/lib/event-summary/item/event-summary-item.component.mjs +3 -3
- package/esm2022/src/lib/event-summary/page/event-summary-page.component.mjs +7 -4
- package/esm2022/src/lib/general/comments/comments.component.mjs +10 -4
- package/esm2022/src/lib/general/display-date.function.mjs +3 -2
- package/esm2022/src/lib/general/i18n/en.translations.mjs +22 -6
- package/esm2022/src/lib/general/i18n/fr.translations.mjs +28 -8
- package/esm2022/src/lib/general/icon-display/icon-display.component.mjs +3 -3
- package/esm2022/src/lib/general/last-events/last-events.component.mjs +34 -4
- package/esm2022/src/lib/general/procedure-actions/action-menu.component.mjs +3 -3
- package/esm2022/src/lib/general/procedure-actions/action-parameters/action-parameter.component.mjs +5 -2
- package/esm2022/src/lib/general/procedure-actions/action-parameters/base-parameter-action.component.mjs +4 -2
- package/esm2022/src/lib/general/procedure-actions/action-parameters/email/email-action-parameter.component.mjs +2 -2
- package/esm2022/src/lib/general/procedure-actions/action-parameters/phone/phone-action-parameter.component.mjs +3 -2
- package/esm2022/src/lib/general/procedure-actions/action-parameters/service/create-service.component.mjs +19 -20
- package/esm2022/src/lib/general/procedure-actions/action-parameters/service/service-action-display.component.mjs +30 -7
- package/esm2022/src/lib/general/procedure-actions/actions-types.constant.mjs +3 -3
- package/esm2022/src/lib/general/procedure-actions/procedure-actions.component.mjs +33 -10
- package/esm2022/src/lib/general/public-api.mjs +2 -1
- package/esm2022/src/lib/general/truncate-pipe/truncate.pipe.mjs +19 -0
- package/esm2022/src/lib/hypervisor.module.mjs +12 -6
- package/esm2022/src/lib/model/event/hyp-event-category.type.mjs +3 -3
- package/esm2022/src/lib/model/event/hyp-event-detail.interface.mjs +3 -2
- package/esm2022/src/lib/model/event/hyp-event-tooltip.interface.mjs +1 -1
- package/esm2022/src/lib/model/hyp-service-status.type.mjs +2 -2
- package/esm2022/src/lib/procedure/model-detail/procedure-model-detail.component.mjs +60 -23
- package/esm2022/src/lib/procedure/model-list/procedure-list.component.mjs +7 -4
- package/esm2022/src/lib/store/service/service.service.mjs +3 -2
- package/fesm2022/provoly-hypervisor.mjs +630 -169
- package/fesm2022/provoly-hypervisor.mjs.map +1 -1
- package/package.json +2 -2
- package/src/lib/auth/hypervisor-roles.contant.d.ts +2 -1
- package/src/lib/event/detail/event-detail.component.d.ts +44 -8
- package/src/lib/event/detail/event-details-tooltip.component.d.ts +4 -1
- package/src/lib/event/filters/text/text-filter.component.d.ts +1 -1
- package/src/lib/event/procedure-association-modal/procedure-association-modal.component.d.ts +4 -1
- package/src/lib/general/comments/comments.component.d.ts +2 -1
- package/src/lib/general/display-date.function.d.ts +1 -1
- package/src/lib/general/i18n/en.translations.d.ts +17 -1
- package/src/lib/general/i18n/fr.translations.d.ts +21 -1
- package/src/lib/general/last-events/last-events.component.d.ts +10 -3
- package/src/lib/general/procedure-actions/action-parameters/action-parameter.component.d.ts +2 -1
- package/src/lib/general/procedure-actions/action-parameters/base-parameter-action.component.d.ts +2 -1
- package/src/lib/general/procedure-actions/action-parameters/phone/phone-action-parameter.component.d.ts +2 -1
- package/src/lib/general/procedure-actions/action-parameters/service/create-service.component.d.ts +4 -9
- package/src/lib/general/procedure-actions/action-parameters/service/service-action-display.component.d.ts +11 -4
- package/src/lib/general/procedure-actions/procedure-actions.component.d.ts +8 -2
- package/src/lib/general/public-api.d.ts +1 -0
- package/src/lib/general/truncate-pipe/truncate.pipe.d.ts +7 -0
- package/src/lib/hypervisor.module.d.ts +2 -1
- package/src/lib/model/event/hyp-event-detail.interface.d.ts +7 -3
- package/src/lib/model/event/hyp-event-tooltip.interface.d.ts +1 -0
- package/src/lib/model/procedure/hyp-procedure.interface.d.ts +4 -2
- package/src/lib/procedure/model-detail/procedure-model-detail.component.d.ts +11 -5
- package/src/lib/procedure/model-list/procedure-list.component.d.ts +2 -1
- package/src/lib/store/service/service.service.d.ts +2 -1
- package/styles/components/_a-chip-status.scss +3 -0
- package/styles/components/_m-hvy-event-summary-item.scss +7 -18
- package/styles/components/_o-hvy-comments.scss +21 -0
- package/styles/components/_o-hvy-event-detail.scss +26 -1
- package/styles/components/_o-hvy-events-table.scss +4 -0
- package/styles/components/_o-hvy-last-events.scss +19 -0
- package/styles/components/_o-hvy-procedure-actions.scss +2 -1
|
@@ -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/
|
|
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,17 +20,38 @@ export class ProcedureModelDetailComponent extends SubscriptionnerDirective {
|
|
|
17
20
|
get modifiedModel() {
|
|
18
21
|
return { ...this.model, ...(this.modifications ?? {}) };
|
|
19
22
|
}
|
|
20
|
-
constructor(
|
|
23
|
+
constructor(actions$) {
|
|
21
24
|
super();
|
|
22
|
-
this.
|
|
25
|
+
this.actions$ = actions$;
|
|
23
26
|
this.username = 'xxx';
|
|
24
27
|
this.modifications = {};
|
|
28
|
+
this.saved = false;
|
|
25
29
|
this.errors = [];
|
|
26
|
-
this.eventErrors =
|
|
30
|
+
this.eventErrors = [];
|
|
31
|
+
this.eventErrorsChange = new EventEmitter();
|
|
27
32
|
this.modified = new EventEmitter();
|
|
28
33
|
this.DOMAINS = DOMAINS.values;
|
|
29
34
|
this.readonly = false;
|
|
35
|
+
this.readOnlyComment = false;
|
|
30
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
|
+
}));
|
|
49
|
+
this.subscriptions.add(this.actions$.pipe(ofType(ProcedureActions.saveFailure), delay(1000))
|
|
50
|
+
.subscribe({
|
|
51
|
+
next: result => {
|
|
52
|
+
this.saved = false;
|
|
53
|
+
}
|
|
54
|
+
}));
|
|
31
55
|
}
|
|
32
56
|
hasError(prop) {
|
|
33
57
|
return this.errors.find((err) => err.field === prop) ?? false;
|
|
@@ -35,32 +59,41 @@ export class ProcedureModelDetailComponent extends SubscriptionnerDirective {
|
|
|
35
59
|
validate(model) {
|
|
36
60
|
if (!!model) {
|
|
37
61
|
this.errors = [];
|
|
38
|
-
|
|
62
|
+
const regex = new RegExp(/^\s+$/);
|
|
63
|
+
if (!model.name || model.name.length === 0 || regex.test(model.name)) {
|
|
39
64
|
this.errors.push({ field: 'name', code: 'required' });
|
|
40
65
|
}
|
|
41
66
|
if (!model.domain || model.domain.length === 0) {
|
|
42
67
|
this.errors.push({ field: 'domain', code: 'required' });
|
|
43
68
|
}
|
|
44
|
-
if (!model.description || model.description.length === 0) {
|
|
69
|
+
if (!model.description || model.description.length === 0 || regex.test(model.description)) {
|
|
45
70
|
this.errors.push({ field: 'description', code: 'required' });
|
|
46
71
|
}
|
|
47
|
-
this.
|
|
72
|
+
this.eventErrorsChange.next(this.errors);
|
|
48
73
|
}
|
|
49
74
|
}
|
|
50
75
|
modify(prop, $event) {
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
this.modifications[prop] = newValue;
|
|
58
|
-
this._outputModifications();
|
|
76
|
+
if (!this.saved) {
|
|
77
|
+
if (prop === 'name') {
|
|
78
|
+
const index = this.errors.findIndex(error => error.field == 'title');
|
|
79
|
+
if (index !== -1) {
|
|
80
|
+
this.errors.splice(index, 1);
|
|
81
|
+
}
|
|
59
82
|
}
|
|
60
|
-
|
|
83
|
+
// @ts-ignore
|
|
84
|
+
const newValue = $event instanceof Event ? $event.target?.value : $event;
|
|
85
|
+
if (this.model) {
|
|
61
86
|
// @ts-ignore
|
|
62
|
-
|
|
63
|
-
|
|
87
|
+
if (this.model[prop] !== newValue) {
|
|
88
|
+
// @ts-ignore
|
|
89
|
+
this.modifications[prop] = newValue;
|
|
90
|
+
this._outputModifications();
|
|
91
|
+
}
|
|
92
|
+
else {
|
|
93
|
+
// @ts-ignore
|
|
94
|
+
delete this.modifications[prop];
|
|
95
|
+
this._outputModifications();
|
|
96
|
+
}
|
|
64
97
|
}
|
|
65
98
|
}
|
|
66
99
|
}
|
|
@@ -77,25 +110,29 @@ export class ProcedureModelDetailComponent extends SubscriptionnerDirective {
|
|
|
77
110
|
}
|
|
78
111
|
this._outputModifications();
|
|
79
112
|
}
|
|
80
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: ProcedureModelDetailComponent, deps: [{ token: i1.
|
|
81
|
-
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", readonly: "readonly", cancelModifications: "cancelModifications" }, outputs: {
|
|
113
|
+
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 }); }
|
|
114
|
+
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 <!--identifiant-->\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 <!--titre-->\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 <!--metier-->\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 <!--description-->\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 <!--createur-->\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 <!--date de cr\u00E9ation-->\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 <!--date de derni\u00E8re modification-->\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", "refreshActions"] }, { kind: "pipe", type: i3.I18nPipe, name: "i18n" }, { kind: "pipe", type: i5.ForDatetimeLocalPipe, name: "forDateTimeLocal" }] }); }
|
|
82
115
|
}
|
|
83
116
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: ProcedureModelDetailComponent, decorators: [{
|
|
84
117
|
type: Component,
|
|
85
|
-
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
|
|
86
|
-
}], ctorParameters: () => [{ type: i1.
|
|
118
|
+
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 <!--identifiant-->\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 <!--titre-->\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 <!--metier-->\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 <!--description-->\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 <!--createur-->\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 <!--date de cr\u00E9ation-->\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 <!--date de derni\u00E8re modification-->\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" }]
|
|
119
|
+
}], ctorParameters: () => [{ type: i1.Actions }], propDecorators: { model: [{
|
|
87
120
|
type: Input
|
|
88
121
|
}], username: [{
|
|
89
122
|
type: Input
|
|
90
123
|
}], title: [{
|
|
91
124
|
type: Input
|
|
92
125
|
}], eventErrors: [{
|
|
126
|
+
type: Input
|
|
127
|
+
}], eventErrorsChange: [{
|
|
93
128
|
type: Output
|
|
94
129
|
}], modified: [{
|
|
95
130
|
type: Output
|
|
96
131
|
}], readonly: [{
|
|
97
132
|
type: Input
|
|
133
|
+
}], readOnlyComment: [{
|
|
134
|
+
type: Input
|
|
98
135
|
}], cancelModifications: [{
|
|
99
136
|
type: Input
|
|
100
137
|
}] } });
|
|
101
|
-
//# 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  @Output() eventErrors = 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\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.eventErrors.next(this.errors);\n    }\n  }\n\n  modify(prop: string, $event: Event) {\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                </td>\n              </tr>\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              @if (model.id > 0) {\n                <tr>\n                  <td>{{ '@hvy.event.log.event.id' | i18n }} :</td>\n                  <td>\n                    <input type=\"text\" class=\"a-form-field\" [value]=\"padId.fn(model.id)\" readonly />\n                  </td>\n                </tr>\n              }\n              @if (!!model.id) {\n                <tr>\n                  <td>{{ '@hvy.event.creationDate' | i18n }} :</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 }} :</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              }\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            mode=\"model\"\n            [enableEditActions]=\"true\"\n          ></hvy-procedure-actions>\n        </div>\n      }\n    </div>\n  </div>\n</div>\n"]}
|
|
138
|
+
//# 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    this.subscriptions.add(\n      this.actions$.pipe(\n        ofType(ProcedureActions.saveFailure),\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      const regex = new RegExp( /^\\s+$/);\n      if (!model.name || model.name.length === 0 || regex.test(model.name)) {\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 || regex.test(model.description)) {\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              <!--identifiant-->\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              <!--titre-->\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              <!--metier-->\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              <!--description-->\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              <!--createur-->\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              <!--date de création-->\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              <!--date de dernière modification-->\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"]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Component, ViewChild } from '@angular/core';
|
|
1
|
+
import { Component, Input, ViewChild } from '@angular/core';
|
|
2
2
|
import { ProcedureActions } from '../../store/procedure/procedure.actions';
|
|
3
3
|
import { ProcedureSelectors } from '../../store/procedure/procedure.selectors';
|
|
4
4
|
import { SubscriptionnerDirective } from '@provoly/dashboard';
|
|
@@ -27,6 +27,7 @@ export class ProcedureListComponent extends SubscriptionnerDirective {
|
|
|
27
27
|
this.PROCEDURE_LINK = PROCEDURE_LINK;
|
|
28
28
|
this.search = '';
|
|
29
29
|
this.DOMAINS = DOMAINS.values.map((d) => ({ key: d }));
|
|
30
|
+
this.placeholder = '@hvy.action.search';
|
|
30
31
|
this.padId = padId;
|
|
31
32
|
this.store.dispatch(ProcedureActions.load({}));
|
|
32
33
|
this.procedures$ = this.store.select(ProcedureSelectors.procedures);
|
|
@@ -40,13 +41,15 @@ export class ProcedureListComponent extends SubscriptionnerDirective {
|
|
|
40
41
|
return this.router.navigate(this.PROCEDURE_LINK.fn(procedure, this.store));
|
|
41
42
|
}
|
|
42
43
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: ProcedureListComponent, deps: [{ token: i1.Store }, { token: i2.Router }, { token: i3.InfiniteScrollService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
43
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.6", type: ProcedureListComponent, selector: "hvy-procedure-model-list", viewQueries: [{ propertyName: "scrollable", first: true, predicate: ["scrollable"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<div class=\"o-procedure-list\">\n <div class=\"m-form-label-field o-procedure-list__action\">\n <hvy-immediate-filters [filterSet]=\"'procedure'\">\n <hvy-text-filter prop=\"search\" #filter></hvy-text-filter>\n <hvy-choice-filter\n i18nPrefix=\"@hvy.event.domain.\"\n label=\"@hvy.event.domain.name\"\n [choices]=\"DOMAINS\"\n prop=\"domain\"\n #filter\n ></hvy-choice-filter>\n </hvy-immediate-filters>\n </div>\n <div class=\"o-procedure-list__table\" #scrollable>\n <table class=\"o-hvy-events-table\">\n <thead>\n <tr class=\"o-hvy-events-table__header\">\n <th>\n <hvy-procedure-column-order field=\"id\">{{ '@hvy.procedure.id' | i18n }}</hvy-procedure-column-order>\n </th>\n <th>\n <hvy-procedure-column-order field=\"name\">{{ '@hvy.procedure.title' | i18n }}</hvy-procedure-column-order>\n </th>\n <th>\n <hvy-procedure-column-order field=\"domain\">{{ '@hvy.procedure.domain' | i18n }}</hvy-procedure-column-order>\n </th>\n <th>\n <hvy-procedure-column-order field=\"useCount\"\n >{{ '@hvy.procedure.useCount' | i18n }}\n </hvy-procedure-column-order>\n </th>\n <th>\n <hvy-procedure-column-order field=\"creator\"\n >{{ '@hvy.procedure.author' | i18n }}\n </hvy-procedure-column-order>\n </th>\n <th>\n <hvy-procedure-column-order field=\"creationDate\"\n >{{ '@hvy.event.
|
|
44
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.6", type: ProcedureListComponent, selector: "hvy-procedure-model-list", inputs: { placeholder: "placeholder" }, viewQueries: [{ propertyName: "scrollable", first: true, predicate: ["scrollable"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<div class=\"o-procedure-list\">\n <div class=\"m-form-label-field o-procedure-list__action\">\n <hvy-immediate-filters [filterSet]=\"'procedure'\">\n <hvy-text-filter prop=\"search\" #filter [placeholder]=\"placeholder\"></hvy-text-filter>\n <hvy-choice-filter\n i18nPrefix=\"@hvy.event.domain.\"\n label=\"@hvy.event.domain.name\"\n [choices]=\"DOMAINS\"\n prop=\"domain\"\n #filter\n ></hvy-choice-filter>\n </hvy-immediate-filters>\n </div>\n <div class=\"o-procedure-list__table\" #scrollable>\n <table class=\"o-hvy-events-table\">\n <thead>\n <tr class=\"o-hvy-events-table__header\">\n <th>\n <hvy-procedure-column-order field=\"id\">{{ '@hvy.procedure.id' | i18n }}</hvy-procedure-column-order>\n </th>\n <th>\n <hvy-procedure-column-order field=\"name\">{{ '@hvy.procedure.title' | i18n }}</hvy-procedure-column-order>\n </th>\n <th>\n <hvy-procedure-column-order field=\"domain\">{{ '@hvy.procedure.domain' | i18n }}</hvy-procedure-column-order>\n </th>\n <th>\n <hvy-procedure-column-order field=\"useCount\"\n >{{ '@hvy.procedure.useCount' | i18n }}\n </hvy-procedure-column-order>\n </th>\n <th>\n <hvy-procedure-column-order field=\"creator\"\n >{{ '@hvy.procedure.author' | i18n }}\n </hvy-procedure-column-order>\n </th>\n <th>\n <hvy-procedure-column-order field=\"creationDate\"\n >{{ '@hvy.event.creationDateTable' | i18n }}\n </hvy-procedure-column-order>\n </th>\n <th>\n <hvy-procedure-column-order field=\"lastModificationDate\">\n <span>{{ '@hvy.event.lastModificationDateTable' | i18n }}</span></hvy-procedure-column-order\n >\n </th>\n <th></th>\n </tr>\n </thead>\n <tbody>\n @for (procedure of procedures$ | async; track procedure.id) {\n <tr class=\"o-hvy-events-table__line\" (click)=\"goTo(procedure)\">\n <td class=\"o-hvy-events-table__line__cell\">{{ padId.fn(procedure.id) }}</td>\n <td class=\"o-hvy-events-table__line__cell\">{{ procedure.name }}</td>\n <td class=\"o-hvy-events-table__line__cell\">{{ '@hvy.event.domain.' + procedure.domain | i18n }}</td>\n <td class=\"o-hvy-events-table__line__cell\">{{ procedure.useCount }}</td>\n <td class=\"o-hvy-events-table__line__cell\">{{ procedure.creator }}</td>\n <td class=\"o-hvy-events-table__line__cell\">{{ procedure.creationDate | displayLocaleDatetime }}</td>\n <td class=\"o-hvy-events-table__line__cell\">\n {{ procedure.lastModificationDate | displayLocaleDatetime }}\n </td>\n <td class=\"o-hvy-events-table__line__cell\">\n <a [routerLink]=\"PROCEDURE_LINK.fn(procedure, store)\">\n <div class=\"consult-link\" [title]=\"'@hvy.action.consult' | i18n\">\n <pry-icon iconSvg=\"eye\" [height]=\"30\" [width]=\"40\"></pry-icon>\n </div>\n </a>\n </td>\n </tr>\n } @empty {\n <tr>\n <td class=\"o-hvy-events-table__empty\" colspan=\"50\">\n <div>{{ '@hvy.procedure.noContent' | i18n }}</div>\n <div>\n <ng-content></ng-content>\n </div>\n </td>\n </tr>\n }\n </tbody>\n </table>\n </div>\n</div>\n", dependencies: [{ kind: "directive", type: i2.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "component", type: i4.PryIconComponent, selector: "pry-icon", inputs: ["color", "iconSvg", "animation", "iconImage", "alt", "width", "height", "classes"] }, { kind: "component", type: i5.TextFilterComponent, selector: "hvy-text-filter", inputs: ["placeholder"] }, { kind: "component", type: i6.ChoiceFilterComponent, selector: "hvy-choice-filter", inputs: ["allLabel", "label", "i18nPrefix", "addNonLeaves", "choices"] }, { kind: "component", type: i7.ProcedureColumnOrderComponent, selector: "hvy-procedure-column-order" }, { kind: "component", type: i8.ImmediateFiltersComponent, selector: "hvy-immediate-filters", inputs: ["filterSet", "delay"] }, { kind: "pipe", type: i9.AsyncPipe, name: "async" }, { kind: "pipe", type: i4.I18nPipe, name: "i18n" }, { kind: "pipe", type: i10.DisplayLocaleDateTime, name: "displayLocaleDatetime" }] }); }
|
|
44
45
|
}
|
|
45
46
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: ProcedureListComponent, decorators: [{
|
|
46
47
|
type: Component,
|
|
47
|
-
args: [{ selector: 'hvy-procedure-model-list', template: "<div class=\"o-procedure-list\">\n <div class=\"m-form-label-field o-procedure-list__action\">\n <hvy-immediate-filters [filterSet]=\"'procedure'\">\n <hvy-text-filter prop=\"search\" #filter></hvy-text-filter>\n <hvy-choice-filter\n i18nPrefix=\"@hvy.event.domain.\"\n label=\"@hvy.event.domain.name\"\n [choices]=\"DOMAINS\"\n prop=\"domain\"\n #filter\n ></hvy-choice-filter>\n </hvy-immediate-filters>\n </div>\n <div class=\"o-procedure-list__table\" #scrollable>\n <table class=\"o-hvy-events-table\">\n <thead>\n <tr class=\"o-hvy-events-table__header\">\n <th>\n <hvy-procedure-column-order field=\"id\">{{ '@hvy.procedure.id' | i18n }}</hvy-procedure-column-order>\n </th>\n <th>\n <hvy-procedure-column-order field=\"name\">{{ '@hvy.procedure.title' | i18n }}</hvy-procedure-column-order>\n </th>\n <th>\n <hvy-procedure-column-order field=\"domain\">{{ '@hvy.procedure.domain' | i18n }}</hvy-procedure-column-order>\n </th>\n <th>\n <hvy-procedure-column-order field=\"useCount\"\n >{{ '@hvy.procedure.useCount' | i18n }}\n </hvy-procedure-column-order>\n </th>\n <th>\n <hvy-procedure-column-order field=\"creator\"\n >{{ '@hvy.procedure.author' | i18n }}\n </hvy-procedure-column-order>\n </th>\n <th>\n <hvy-procedure-column-order field=\"creationDate\"\n >{{ '@hvy.event.
|
|
48
|
+
args: [{ selector: 'hvy-procedure-model-list', template: "<div class=\"o-procedure-list\">\n <div class=\"m-form-label-field o-procedure-list__action\">\n <hvy-immediate-filters [filterSet]=\"'procedure'\">\n <hvy-text-filter prop=\"search\" #filter [placeholder]=\"placeholder\"></hvy-text-filter>\n <hvy-choice-filter\n i18nPrefix=\"@hvy.event.domain.\"\n label=\"@hvy.event.domain.name\"\n [choices]=\"DOMAINS\"\n prop=\"domain\"\n #filter\n ></hvy-choice-filter>\n </hvy-immediate-filters>\n </div>\n <div class=\"o-procedure-list__table\" #scrollable>\n <table class=\"o-hvy-events-table\">\n <thead>\n <tr class=\"o-hvy-events-table__header\">\n <th>\n <hvy-procedure-column-order field=\"id\">{{ '@hvy.procedure.id' | i18n }}</hvy-procedure-column-order>\n </th>\n <th>\n <hvy-procedure-column-order field=\"name\">{{ '@hvy.procedure.title' | i18n }}</hvy-procedure-column-order>\n </th>\n <th>\n <hvy-procedure-column-order field=\"domain\">{{ '@hvy.procedure.domain' | i18n }}</hvy-procedure-column-order>\n </th>\n <th>\n <hvy-procedure-column-order field=\"useCount\"\n >{{ '@hvy.procedure.useCount' | i18n }}\n </hvy-procedure-column-order>\n </th>\n <th>\n <hvy-procedure-column-order field=\"creator\"\n >{{ '@hvy.procedure.author' | i18n }}\n </hvy-procedure-column-order>\n </th>\n <th>\n <hvy-procedure-column-order field=\"creationDate\"\n >{{ '@hvy.event.creationDateTable' | i18n }}\n </hvy-procedure-column-order>\n </th>\n <th>\n <hvy-procedure-column-order field=\"lastModificationDate\">\n <span>{{ '@hvy.event.lastModificationDateTable' | i18n }}</span></hvy-procedure-column-order\n >\n </th>\n <th></th>\n </tr>\n </thead>\n <tbody>\n @for (procedure of procedures$ | async; track procedure.id) {\n <tr class=\"o-hvy-events-table__line\" (click)=\"goTo(procedure)\">\n <td class=\"o-hvy-events-table__line__cell\">{{ padId.fn(procedure.id) }}</td>\n <td class=\"o-hvy-events-table__line__cell\">{{ procedure.name }}</td>\n <td class=\"o-hvy-events-table__line__cell\">{{ '@hvy.event.domain.' + procedure.domain | i18n }}</td>\n <td class=\"o-hvy-events-table__line__cell\">{{ procedure.useCount }}</td>\n <td class=\"o-hvy-events-table__line__cell\">{{ procedure.creator }}</td>\n <td class=\"o-hvy-events-table__line__cell\">{{ procedure.creationDate | displayLocaleDatetime }}</td>\n <td class=\"o-hvy-events-table__line__cell\">\n {{ procedure.lastModificationDate | displayLocaleDatetime }}\n </td>\n <td class=\"o-hvy-events-table__line__cell\">\n <a [routerLink]=\"PROCEDURE_LINK.fn(procedure, store)\">\n <div class=\"consult-link\" [title]=\"'@hvy.action.consult' | i18n\">\n <pry-icon iconSvg=\"eye\" [height]=\"30\" [width]=\"40\"></pry-icon>\n </div>\n </a>\n </td>\n </tr>\n } @empty {\n <tr>\n <td class=\"o-hvy-events-table__empty\" colspan=\"50\">\n <div>{{ '@hvy.procedure.noContent' | i18n }}</div>\n <div>\n <ng-content></ng-content>\n </div>\n </td>\n </tr>\n }\n </tbody>\n </table>\n </div>\n</div>\n" }]
|
|
48
49
|
}], ctorParameters: () => [{ type: i1.Store }, { type: i2.Router }, { type: i3.InfiniteScrollService }], propDecorators: { scrollable: [{
|
|
49
50
|
type: ViewChild,
|
|
50
51
|
args: ['scrollable']
|
|
52
|
+
}], placeholder: [{
|
|
53
|
+
type: Input
|
|
51
54
|
}] } });
|
|
52
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"procedure-list.component.js","sourceRoot":"","sources":["../../../../../../../../projects/provoly/hypervisor/src/lib/procedure/model-list/procedure-list.component.ts","../../../../../../../../projects/provoly/hypervisor/src/lib/procedure/model-list/procedure-list.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAiB,SAAS,EAAyB,SAAS,EAAE,MAAM,eAAe,CAAC;AAG3F,OAAO,EAAE,gBAAgB,EAAE,MAAM,yCAAyC,CAAC;AAE3E,OAAO,EAAE,kBAAkB,EAAE,MAAM,2CAA2C,CAAC;AAE/E,OAAO,EAAE,wBAAwB,EAAE,MAAM,oBAAoB,CAAC;AAE9D,OAAO,EAAE,OAAO,EAAE,MAAM,8BAA8B,CAAC;AACvD,OAAO,EAAE,KAAK,EAAE,MAAM,+BAA+B,CAAC;;;;;;;;;;;;AAEtD,MAAM,CAAC,MAAM,cAAc,GAAG;IAC5B,EAAE,EAAE,CAAC,SAA4B,EAAE,KAAiB,EAAE,EAAE,CAAC,CAAC,IAAI,EAAE,KAAK,CAAC,EAAE,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC;CACxF,CAAC;AAMF,MAAM,OAAO,sBAAuB,SAAQ,wBAAwB;IAOlE,YACY,KAAiB,EACnB,MAAc,EACd,MAA6B;QAErC,KAAK,EAAE,CAAC;QAJE,UAAK,GAAL,KAAK,CAAY;QACnB,WAAM,GAAN,MAAM,CAAQ;QACd,WAAM,GAAN,MAAM,CAAuB;QARvC,mBAAc,GAAG,cAAc,CAAC;QAChC,WAAM,GAAW,EAAE,CAAC;QACD,YAAO,GAAG,OAAO,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QAyBlD,UAAK,GAAG,KAAK,CAAC;QAhB/B,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,gBAAgB,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC;QAC/C,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,kBAAkB,CAAC,UAAU,CAAC,CAAC;IACtE,CAAC;IAED,eAAe;QACb,IAAI,CAAC,aAAa,CAAC,GAAG,CACpB,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,EAAE,kBAAkB,CAAC,gBAAgB,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;YACzG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,gBAAgB,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC;QAC7D,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;IAED,IAAI,CAAC,SAA4B;QAC/B,OAAO,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,cAAc,CAAC,EAAE,CAAC,SAAS,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;IAC7E,CAAC;8GA3BU,sBAAsB;kGAAtB,sBAAsB,iMCpBnC,49GAmFA;;2FD/Da,sBAAsB;kBAJlC,SAAS;+BACE,0BAA0B;mIAQX,UAAU;sBAAlC,SAAS;uBAAC,YAAY","sourcesContent":["import { AfterViewInit, Component, ElementRef, OnDestroy, ViewChild } from '@angular/core';\nimport { Router } from '@angular/router';\nimport { Store } from '@ngrx/store';\nimport { ProcedureActions } from '../../store/procedure/procedure.actions';\nimport { Observable } from 'rxjs';\nimport { ProcedureSelectors } from '../../store/procedure/procedure.selectors';\nimport { HypProcedureModel } from '../../model/procedure/hyp-procedure-model.interface';\nimport { SubscriptionnerDirective } from '@provoly/dashboard';\nimport { InfiniteScrollService } from '../../general/infiniteScroll.service';\nimport { DOMAINS } from '../../model/domains.constant';\nimport { padId } from '../../general/pad-id.function';\n\nexport const PROCEDURE_LINK = {\n  fn: (procedure: HypProcedureModel, store: Store<any>) => ['./', padId.fn(procedure.id)]\n};\n\n@Component({\n  selector: 'hvy-procedure-model-list',\n  templateUrl: './procedure-list.component.html'\n})\nexport class ProcedureListComponent extends SubscriptionnerDirective implements AfterViewInit, OnDestroy {\n  procedures$: Observable<HypProcedureModel[]>;\n  PROCEDURE_LINK = PROCEDURE_LINK;\n  search: string = '';\n  protected readonly DOMAINS = DOMAINS.values.map((d) => ({ key: d }));\n  @ViewChild('scrollable') scrollable!: ElementRef;\n\n  constructor(\n    protected store: Store<any>,\n    private router: Router,\n    private scroll: InfiniteScrollService\n  ) {\n    super();\n    this.store.dispatch(ProcedureActions.load({}));\n    this.procedures$ = this.store.select(ProcedureSelectors.procedures);\n  }\n\n  ngAfterViewInit(): void {\n    this.subscriptions.add(\n      this.scroll.isEndOfPage(this.scrollable.nativeElement, ProcedureSelectors.noMoreProcedures).subscribe(() => {\n        this.store.dispatch(ProcedureActions.load({ next: true }));\n      })\n    );\n  }\n\n  goTo(procedure: HypProcedureModel) {\n    return this.router.navigate(this.PROCEDURE_LINK.fn(procedure, this.store));\n  }\n\n  protected readonly padId = padId;\n}\n","<div class=\"o-procedure-list\">\n  <div class=\"m-form-label-field o-procedure-list__action\">\n    <hvy-immediate-filters [filterSet]=\"'procedure'\">\n      <hvy-text-filter prop=\"search\" #filter></hvy-text-filter>\n      <hvy-choice-filter\n        i18nPrefix=\"@hvy.event.domain.\"\n        label=\"@hvy.event.domain.name\"\n        [choices]=\"DOMAINS\"\n        prop=\"domain\"\n        #filter\n      ></hvy-choice-filter>\n    </hvy-immediate-filters>\n  </div>\n  <div class=\"o-procedure-list__table\" #scrollable>\n    <table class=\"o-hvy-events-table\">\n      <thead>\n        <tr class=\"o-hvy-events-table__header\">\n          <th>\n            <hvy-procedure-column-order field=\"id\">{{ '@hvy.procedure.id' | i18n }}</hvy-procedure-column-order>\n          </th>\n          <th>\n            <hvy-procedure-column-order field=\"name\">{{ '@hvy.procedure.title' | i18n }}</hvy-procedure-column-order>\n          </th>\n          <th>\n            <hvy-procedure-column-order field=\"domain\">{{ '@hvy.procedure.domain' | i18n }}</hvy-procedure-column-order>\n          </th>\n          <th>\n            <hvy-procedure-column-order field=\"useCount\"\n              >{{ '@hvy.procedure.useCount' | i18n }}\n            </hvy-procedure-column-order>\n          </th>\n          <th>\n            <hvy-procedure-column-order field=\"creator\"\n              >{{ '@hvy.procedure.author' | i18n }}\n            </hvy-procedure-column-order>\n          </th>\n          <th>\n            <hvy-procedure-column-order field=\"creationDate\"\n              >{{ '@hvy.event.creationDate' | i18n }}\n            </hvy-procedure-column-order>\n          </th>\n          <th>\n            <hvy-procedure-column-order field=\"lastModificationDate\">\n              <span>{{ '@hvy.event.lastModificationDate' | i18n }}</span></hvy-procedure-column-order\n            >\n          </th>\n          <th></th>\n        </tr>\n      </thead>\n      <tbody>\n        @for (procedure of procedures$ | async; track procedure.id) {\n          <tr class=\"o-hvy-events-table__line\" (click)=\"goTo(procedure)\">\n            <td class=\"o-hvy-events-table__line__cell\">{{ padId.fn(procedure.id) }}</td>\n            <td class=\"o-hvy-events-table__line__cell\">{{ procedure.name }}</td>\n            <td class=\"o-hvy-events-table__line__cell\">{{ '@hvy.event.domain.' + procedure.domain | i18n }}</td>\n            <td class=\"o-hvy-events-table__line__cell\">{{ procedure.useCount }}</td>\n            <td class=\"o-hvy-events-table__line__cell\">{{ procedure.creator }}</td>\n            <td class=\"o-hvy-events-table__line__cell\">{{ procedure.creationDate | displayLocaleDatetime }}</td>\n            <td class=\"o-hvy-events-table__line__cell\">\n              {{ procedure.lastModificationDate | displayLocaleDatetime }}\n            </td>\n            <td class=\"o-hvy-events-table__line__cell\">\n              <a [routerLink]=\"PROCEDURE_LINK.fn(procedure, store)\">\n                <div class=\"consult-link\">\n                  <pry-icon iconSvg=\"eye\" [height]=\"30\" [width]=\"40\"></pry-icon>\n                </div>\n              </a>\n            </td>\n          </tr>\n        } @empty {\n          <tr>\n            <td class=\"o-hvy-events-table__empty\" colspan=\"50\">\n              <div>{{ '@hvy.procedure.noContent' | i18n }}</div>\n              <div>\n                <ng-content></ng-content>\n              </div>\n            </td>\n          </tr>\n        }\n      </tbody>\n    </table>\n  </div>\n</div>\n"]}
|
|
55
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"procedure-list.component.js","sourceRoot":"","sources":["../../../../../../../../projects/provoly/hypervisor/src/lib/procedure/model-list/procedure-list.component.ts","../../../../../../../../projects/provoly/hypervisor/src/lib/procedure/model-list/procedure-list.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAiB,SAAS,EAAc,KAAK,EAAa,SAAS,EAAE,MAAM,eAAe,CAAC;AAGlG,OAAO,EAAE,gBAAgB,EAAE,MAAM,yCAAyC,CAAC;AAE3E,OAAO,EAAE,kBAAkB,EAAE,MAAM,2CAA2C,CAAC;AAE/E,OAAO,EAAE,wBAAwB,EAAE,MAAM,oBAAoB,CAAC;AAE9D,OAAO,EAAE,OAAO,EAAE,MAAM,8BAA8B,CAAC;AACvD,OAAO,EAAE,KAAK,EAAE,MAAM,+BAA+B,CAAC;;;;;;;;;;;;AAEtD,MAAM,CAAC,MAAM,cAAc,GAAG;IAC5B,EAAE,EAAE,CAAC,SAA4B,EAAE,KAAiB,EAAE,EAAE,CAAC,CAAC,IAAI,EAAE,KAAK,CAAC,EAAE,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC;CACxF,CAAC;AAMF,MAAM,OAAO,sBAAuB,SAAQ,wBAAwB;IAQlE,YACY,KAAiB,EACnB,MAAc,EACd,MAA6B;QAErC,KAAK,EAAE,CAAC;QAJE,UAAK,GAAL,KAAK,CAAY;QACnB,WAAM,GAAN,MAAM,CAAQ;QACd,WAAM,GAAN,MAAM,CAAuB;QATvC,mBAAc,GAAG,cAAc,CAAC;QAChC,WAAM,GAAW,EAAE,CAAC;QACD,YAAO,GAAG,OAAO,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QAE5D,gBAAW,GAAW,oBAAoB,CAAC;QAwBjC,UAAK,GAAG,KAAK,CAAC;QAhB/B,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,gBAAgB,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC;QAC/C,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,kBAAkB,CAAC,UAAU,CAAC,CAAC;IACtE,CAAC;IAED,eAAe;QACb,IAAI,CAAC,aAAa,CAAC,GAAG,CACpB,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,EAAE,kBAAkB,CAAC,gBAAgB,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;YACzG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,gBAAgB,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC;QAC7D,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;IAED,IAAI,CAAC,SAA4B;QAC/B,OAAO,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,cAAc,CAAC,EAAE,CAAC,SAAS,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;IAC7E,CAAC;8GA5BU,sBAAsB;kGAAtB,sBAAsB,yOCpBnC,6iHAmFA;;2FD/Da,sBAAsB;kBAJlC,SAAS;+BACE,0BAA0B;mIAQX,UAAU;sBAAlC,SAAS;uBAAC,YAAY;gBACd,WAAW;sBAAnB,KAAK","sourcesContent":["import { AfterViewInit, Component, ElementRef, Input, OnDestroy, ViewChild } from '@angular/core';\nimport { Router } from '@angular/router';\nimport { Store } from '@ngrx/store';\nimport { ProcedureActions } from '../../store/procedure/procedure.actions';\nimport { Observable } from 'rxjs';\nimport { ProcedureSelectors } from '../../store/procedure/procedure.selectors';\nimport { HypProcedureModel } from '../../model/procedure/hyp-procedure-model.interface';\nimport { SubscriptionnerDirective } from '@provoly/dashboard';\nimport { InfiniteScrollService } from '../../general/infiniteScroll.service';\nimport { DOMAINS } from '../../model/domains.constant';\nimport { padId } from '../../general/pad-id.function';\n\nexport const PROCEDURE_LINK = {\n  fn: (procedure: HypProcedureModel, store: Store<any>) => ['./', padId.fn(procedure.id)]\n};\n\n@Component({\n  selector: 'hvy-procedure-model-list',\n  templateUrl: './procedure-list.component.html'\n})\nexport class ProcedureListComponent extends SubscriptionnerDirective implements AfterViewInit, OnDestroy {\n  procedures$: Observable<HypProcedureModel[]>;\n  PROCEDURE_LINK = PROCEDURE_LINK;\n  search: string = '';\n  protected readonly DOMAINS = DOMAINS.values.map((d) => ({ key: d }));\n  @ViewChild('scrollable') scrollable!: ElementRef;\n  @Input() placeholder: string = '@hvy.action.search';\n\n  constructor(\n    protected store: Store<any>,\n    private router: Router,\n    private scroll: InfiniteScrollService\n  ) {\n    super();\n    this.store.dispatch(ProcedureActions.load({}));\n    this.procedures$ = this.store.select(ProcedureSelectors.procedures);\n  }\n\n  ngAfterViewInit(): void {\n    this.subscriptions.add(\n      this.scroll.isEndOfPage(this.scrollable.nativeElement, ProcedureSelectors.noMoreProcedures).subscribe(() => {\n        this.store.dispatch(ProcedureActions.load({ next: true }));\n      })\n    );\n  }\n\n  goTo(procedure: HypProcedureModel) {\n    return this.router.navigate(this.PROCEDURE_LINK.fn(procedure, this.store));\n  }\n\n  protected readonly padId = padId;\n}\n","<div class=\"o-procedure-list\">\n  <div class=\"m-form-label-field o-procedure-list__action\">\n    <hvy-immediate-filters [filterSet]=\"'procedure'\">\n      <hvy-text-filter prop=\"search\" #filter [placeholder]=\"placeholder\"></hvy-text-filter>\n      <hvy-choice-filter\n        i18nPrefix=\"@hvy.event.domain.\"\n        label=\"@hvy.event.domain.name\"\n        [choices]=\"DOMAINS\"\n        prop=\"domain\"\n        #filter\n      ></hvy-choice-filter>\n    </hvy-immediate-filters>\n  </div>\n  <div class=\"o-procedure-list__table\" #scrollable>\n    <table class=\"o-hvy-events-table\">\n      <thead>\n        <tr class=\"o-hvy-events-table__header\">\n          <th>\n            <hvy-procedure-column-order field=\"id\">{{ '@hvy.procedure.id' | i18n }}</hvy-procedure-column-order>\n          </th>\n          <th>\n            <hvy-procedure-column-order field=\"name\">{{ '@hvy.procedure.title' | i18n }}</hvy-procedure-column-order>\n          </th>\n          <th>\n            <hvy-procedure-column-order field=\"domain\">{{ '@hvy.procedure.domain' | i18n }}</hvy-procedure-column-order>\n          </th>\n          <th>\n            <hvy-procedure-column-order field=\"useCount\"\n              >{{ '@hvy.procedure.useCount' | i18n }}\n            </hvy-procedure-column-order>\n          </th>\n          <th>\n            <hvy-procedure-column-order field=\"creator\"\n              >{{ '@hvy.procedure.author' | i18n }}\n            </hvy-procedure-column-order>\n          </th>\n          <th>\n            <hvy-procedure-column-order field=\"creationDate\"\n              >{{ '@hvy.event.creationDateTable' | i18n }}\n            </hvy-procedure-column-order>\n          </th>\n          <th>\n            <hvy-procedure-column-order field=\"lastModificationDate\">\n              <span>{{ '@hvy.event.lastModificationDateTable' | i18n }}</span></hvy-procedure-column-order\n            >\n          </th>\n          <th></th>\n        </tr>\n      </thead>\n      <tbody>\n        @for (procedure of procedures$ | async; track procedure.id) {\n          <tr class=\"o-hvy-events-table__line\" (click)=\"goTo(procedure)\">\n            <td class=\"o-hvy-events-table__line__cell\">{{ padId.fn(procedure.id) }}</td>\n            <td class=\"o-hvy-events-table__line__cell\">{{ procedure.name }}</td>\n            <td class=\"o-hvy-events-table__line__cell\">{{ '@hvy.event.domain.' + procedure.domain | i18n }}</td>\n            <td class=\"o-hvy-events-table__line__cell\">{{ procedure.useCount }}</td>\n            <td class=\"o-hvy-events-table__line__cell\">{{ procedure.creator }}</td>\n            <td class=\"o-hvy-events-table__line__cell\">{{ procedure.creationDate | displayLocaleDatetime }}</td>\n            <td class=\"o-hvy-events-table__line__cell\">\n              {{ procedure.lastModificationDate | displayLocaleDatetime }}\n            </td>\n            <td class=\"o-hvy-events-table__line__cell\">\n              <a [routerLink]=\"PROCEDURE_LINK.fn(procedure, store)\">\n                <div class=\"consult-link\" [title]=\"'@hvy.action.consult' | i18n\">\n                  <pry-icon iconSvg=\"eye\" [height]=\"30\" [width]=\"40\"></pry-icon>\n                </div>\n              </a>\n            </td>\n          </tr>\n        } @empty {\n          <tr>\n            <td class=\"o-hvy-events-table__empty\" colspan=\"50\">\n              <div>{{ '@hvy.procedure.noContent' | i18n }}</div>\n              <div>\n                <ng-content></ng-content>\n              </div>\n            </td>\n          </tr>\n        }\n      </tbody>\n    </table>\n  </div>\n</div>\n"]}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { Injectable } from '@angular/core';
|
|
2
|
-
import { mergeMap } from 'rxjs';
|
|
2
|
+
import { mergeMap, Subject } from 'rxjs';
|
|
3
3
|
import { HypSelectors } from '../hypervisor/hypervisor.selectors';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
import * as i1 from "@angular/common/http";
|
|
@@ -8,6 +8,7 @@ export class ServiceService {
|
|
|
8
8
|
constructor(httpClient, store) {
|
|
9
9
|
this.httpClient = httpClient;
|
|
10
10
|
this.store = store;
|
|
11
|
+
this.refreshDiAction = new Subject();
|
|
11
12
|
}
|
|
12
13
|
types() {
|
|
13
14
|
return this.store.select(HypSelectors.url).pipe(mergeMap((url) => {
|
|
@@ -28,4 +29,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImpor
|
|
|
28
29
|
providedIn: 'root'
|
|
29
30
|
}]
|
|
30
31
|
}], ctorParameters: () => [{ type: i1.HttpClient }, { type: i2.Store }] });
|
|
31
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
32
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VydmljZS5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvcHJvdm9seS9oeXBlcnZpc29yL3NyYy9saWIvc3RvcmUvc2VydmljZS9zZXJ2aWNlLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFVBQVUsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUV6QyxPQUFPLEVBQUMsUUFBUSxFQUFjLE9BQU8sRUFBQyxNQUFNLE1BQU0sQ0FBQztBQUVuRCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sb0NBQW9DLENBQUM7Ozs7QUFxQmxFLE1BQU0sT0FBTyxjQUFjO0lBRXpCLFlBQ1UsVUFBc0IsRUFDdEIsS0FBaUI7UUFEakIsZUFBVSxHQUFWLFVBQVUsQ0FBWTtRQUN0QixVQUFLLEdBQUwsS0FBSyxDQUFZO1FBSHBCLG9CQUFlLEdBQUcsSUFBSSxPQUFPLEVBQUUsQ0FBQztJQUlwQyxDQUFDO0lBRUosS0FBSztRQUNILE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsWUFBWSxDQUFDLEdBQUcsQ0FBQyxDQUFDLElBQUksQ0FDN0MsUUFBUSxDQUFDLENBQUMsR0FBRyxFQUFFLEVBQUU7WUFDZixPQUFPLElBQUksQ0FBQyxVQUFVLENBQUMsR0FBRyxDQUFtQixTQUFTLENBQUMsR0FBRyxHQUFHLGVBQWUsQ0FBQyxDQUFDLENBQUM7UUFDakYsQ0FBQyxDQUFDLENBQ0gsQ0FBQztJQUNKLENBQUM7SUFFRCxNQUFNLENBQUMsT0FBbUIsRUFBRSxRQUFnQjtRQUMxQyxPQUFPLElBQUksQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLFlBQVksQ0FBQyxHQUFHLENBQUMsQ0FBQyxJQUFJLENBQzdDLFFBQVEsQ0FBQyxDQUFDLEdBQUcsRUFBRSxFQUFFO1lBQ2YsT0FBTyxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBaUIsU0FBUyxDQUFDLEdBQUcsR0FBRyx5QkFBeUIsUUFBUSxFQUFFLENBQUMsRUFBRSxPQUFPLENBQUMsQ0FBQztRQUM3RyxDQUFDLENBQUMsQ0FDSCxDQUFDO0lBQ0osQ0FBQzs4R0FyQlUsY0FBYztrSEFBZCxjQUFjLGNBRmIsTUFBTTs7MkZBRVAsY0FBYztrQkFIMUIsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0luamVjdGFibGV9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgSHR0cENsaWVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbi9odHRwJztcbmltcG9ydCB7bWVyZ2VNYXAsIE9ic2VydmFibGUsIFN1YmplY3R9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgU3RvcmUgfSBmcm9tICdAbmdyeC9zdG9yZSc7XG5pbXBvcnQgeyBIeXBTZWxlY3RvcnMgfSBmcm9tICcuLi9oeXBlcnZpc29yL2h5cGVydmlzb3Iuc2VsZWN0b3JzJztcblxuZXhwb3J0IGludGVyZmFjZSBIeXBTZXJ2aWNlVHlwZSB7XG4gIG5hbWU6IHN0cmluZztcbiAgZG9tYWluOiBzdHJpbmc7XG4gIGd0aTogbnVtYmVyO1xuICBndHI6IG51bWJlcjtcbiAgZ3RycDogbnVtYmVyO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEh5cFNlcnZpY2Uge1xuICBuYW1lOiBzdHJpbmc7XG4gIGVxdWlwbWVudDogc3RyaW5nO1xuICBwcmlvcml0eTogc3RyaW5nO1xuICB0eXBlOiBzdHJpbmc7XG4gIGRlc2NyaXB0aW9uOiBzdHJpbmc7XG59XG5cbkBJbmplY3RhYmxlKHtcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnXG59KVxuZXhwb3J0IGNsYXNzIFNlcnZpY2VTZXJ2aWNlIHtcbiAgcHVibGljIHJlZnJlc2hEaUFjdGlvbiA9IG5ldyBTdWJqZWN0KCk7XG4gIGNvbnN0cnVjdG9yKFxuICAgIHByaXZhdGUgaHR0cENsaWVudDogSHR0cENsaWVudCxcbiAgICBwcml2YXRlIHN0b3JlOiBTdG9yZTxhbnk+XG4gICkge31cblxuICB0eXBlcygpOiBPYnNlcnZhYmxlPEh5cFNlcnZpY2VUeXBlW10+IHtcbiAgICByZXR1cm4gdGhpcy5zdG9yZS5zZWxlY3QoSHlwU2VsZWN0b3JzLnVybCkucGlwZShcbiAgICAgIG1lcmdlTWFwKCh1cmwpID0+IHtcbiAgICAgICAgcmV0dXJuIHRoaXMuaHR0cENsaWVudC5nZXQ8SHlwU2VydmljZVR5cGVbXT4oZW5jb2RlVVJJKGAke3VybH0vc2VydmljZXNUeXBlYCkpO1xuICAgICAgfSlcbiAgICApO1xuICB9XG5cbiAgY3JlYXRlKHNlcnZpY2U6IEh5cFNlcnZpY2UsIGFjdGlvbklkOiBzdHJpbmcpIHtcbiAgICByZXR1cm4gdGhpcy5zdG9yZS5zZWxlY3QoSHlwU2VsZWN0b3JzLnVybCkucGlwZShcbiAgICAgIG1lcmdlTWFwKCh1cmwpID0+IHtcbiAgICAgICAgcmV0dXJuIHRoaXMuaHR0cENsaWVudC5wb3N0PHsgaWQ6IHN0cmluZyB9PihlbmNvZGVVUkkoYCR7dXJsfS9zZXJ2aWNlcy9leHRlcm5hbC9pZC8ke2FjdGlvbklkfWApLCBzZXJ2aWNlKTtcbiAgICAgIH0pXG4gICAgKTtcbiAgfVxufVxuIl19
|