@provoly/hypervisor 2.3.0 → 2.3.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/event/detail/event-detail.component.mjs +10 -10
- package/esm2022/src/lib/event/list/event-list.component.mjs +3 -3
- package/esm2022/src/lib/general/i18n/fr.translations.mjs +6 -2
- package/esm2022/src/lib/model/procedure/hyp-procedure-model.interface.mjs +1 -1
- package/esm2022/src/lib/procedure/model-detail/procedure-model-detail.component.mjs +6 -5
- package/esm2022/src/lib/procedure/model-list/procedure-list.component.mjs +8 -8
- package/esm2022/src/lib/store/procedure/procedure.service.mjs +2 -2
- package/fesm2022/provoly-hypervisor.mjs +32 -28
- package/fesm2022/provoly-hypervisor.mjs.map +1 -1
- package/package.json +1 -1
- package/src/lib/general/i18n/fr.translations.d.ts +4 -0
- package/src/lib/model/procedure/hyp-procedure-model.interface.d.ts +2 -0
- package/styles/components/_o-hvy-events-table.scss +11 -3
- package/styles/components/_o-hvy-procedure-detail.scss +15 -0
- package/styles/components/_o-hvy-procedure-list.scss +2 -12
|
@@ -9,11 +9,11 @@ import * as i1 from "@ngrx/store";
|
|
|
9
9
|
import * as i2 from "@angular/router";
|
|
10
10
|
import * as i3 from "../../general/infiniteScroll.service";
|
|
11
11
|
import * as i4 from "@provoly/dashboard";
|
|
12
|
-
import * as i5 from "
|
|
13
|
-
import * as i6 from "../../event/filters/
|
|
14
|
-
import * as i7 from "
|
|
15
|
-
import * as i8 from "
|
|
16
|
-
import * as i9 from "
|
|
12
|
+
import * as i5 from "@angular/common";
|
|
13
|
+
import * as i6 from "../../event/filters/text/text-filter.component";
|
|
14
|
+
import * as i7 from "../../event/filters/choice/choice-filter.component";
|
|
15
|
+
import * as i8 from "./procedure-column-order.component";
|
|
16
|
+
import * as i9 from "../../event/filters/on/immediate/immediate-filters.component";
|
|
17
17
|
import * as i10 from "../../general/display-locale-datetime/display-locale-datetime.pipe";
|
|
18
18
|
export const PROCEDURE_LINK = {
|
|
19
19
|
fn: (procedure, store) => ['./', padId.fn(procedure.id)]
|
|
@@ -41,15 +41,15 @@ export class ProcedureListComponent extends SubscriptionnerDirective {
|
|
|
41
41
|
return this.router.navigate(this.PROCEDURE_LINK.fn(procedure, this.store));
|
|
42
42
|
}
|
|
43
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 }); }
|
|
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>\n <hvy-procedure-column-order field=\"etat\">\n <span>{{ '@hvy.procedure.etat' | 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\"
|
|
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>\n <hvy-procedure-column-order field=\"etat\">\n <span>{{ '@hvy.procedure.etat' | 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 <span class=\"slt-ind2-bubble-container\">\n <div [ngClass]=\"procedure.active ? '-green' : '-red'\">{{ '@hvy.procedure.status.active.' + procedure.active | i18n }}</div>\n </span>\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: "directive", type: i5.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: i6.TextFilterComponent, selector: "hvy-text-filter", inputs: ["placeholder"] }, { kind: "component", type: i7.ChoiceFilterComponent, selector: "hvy-choice-filter", inputs: ["allLabel", "label", "i18nPrefix", "addNonLeaves", "choices"] }, { kind: "component", type: i8.ProcedureColumnOrderComponent, selector: "hvy-procedure-column-order" }, { kind: "component", type: i9.ImmediateFiltersComponent, selector: "hvy-immediate-filters", inputs: ["filterSet", "delay"] }, { kind: "pipe", type: i5.AsyncPipe, name: "async" }, { kind: "pipe", type: i4.I18nPipe, name: "i18n" }, { kind: "pipe", type: i10.DisplayLocaleDateTime, name: "displayLocaleDatetime" }] }); }
|
|
45
45
|
}
|
|
46
46
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: ProcedureListComponent, decorators: [{
|
|
47
47
|
type: Component,
|
|
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>\n <hvy-procedure-column-order field=\"etat\">\n <span>{{ '@hvy.procedure.etat' | 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\"
|
|
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>\n <hvy-procedure-column-order field=\"etat\">\n <span>{{ '@hvy.procedure.etat' | 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 <span class=\"slt-ind2-bubble-container\">\n <div [ngClass]=\"procedure.active ? '-green' : '-red'\">{{ '@hvy.procedure.status.active.' + procedure.active | i18n }}</div>\n </span>\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" }]
|
|
49
49
|
}], ctorParameters: () => [{ type: i1.Store }, { type: i2.Router }, { type: i3.InfiniteScrollService }], propDecorators: { scrollable: [{
|
|
50
50
|
type: ViewChild,
|
|
51
51
|
args: ['scrollable']
|
|
52
52
|
}], placeholder: [{
|
|
53
53
|
type: Input
|
|
54
54
|
}] } });
|
|
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,m0HAyFA;;2FDrEa,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>\n            <hvy-procedure-column-order field=\"etat\">\n              <span>{{ '@hvy.procedure.etat' | 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\"><div>Inactif</div></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"]}
|
|
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,giIA6FA;;2FDzEa,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>\n            <hvy-procedure-column-order field=\"etat\">\n              <span>{{ '@hvy.procedure.etat' | 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              <span class=\"slt-ind2-bubble-container\">\n                <div [ngClass]=\"procedure.active ? '-green' : '-red'\">{{ '@hvy.procedure.status.active.' + procedure.active | i18n  }}</div>\n              </span>\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"]}
|
|
@@ -35,7 +35,7 @@ export class ProcedureService {
|
|
|
35
35
|
getTop10ByUsage(domain, search) {
|
|
36
36
|
return this.store.select(HypSelectors.url).pipe(mergeMap((url) => {
|
|
37
37
|
let params = new HttpParams();
|
|
38
|
-
params = params.set('sort', 'useCount').set('order', 'DESC').set('pageSize', '10');
|
|
38
|
+
params = params.set('sort', 'useCount').set('order', 'DESC').set('pageSize', '10').set('active', 'true');
|
|
39
39
|
if (search)
|
|
40
40
|
params = params.set('search', search);
|
|
41
41
|
if (domain)
|
|
@@ -72,4 +72,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImpor
|
|
|
72
72
|
providedIn: 'root'
|
|
73
73
|
}]
|
|
74
74
|
}], ctorParameters: () => [{ type: i1.HttpClient }, { type: i2.Store }] });
|
|
75
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
75
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"procedure.service.js","sourceRoot":"","sources":["../../../../../../../../projects/provoly/hypervisor/src/lib/store/procedure/procedure.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { HttpClient, HttpParams } from '@angular/common/http';\nimport { combineLatest, map, mergeMap, Observable } from 'rxjs';\nimport { Store } from '@ngrx/store';\nimport { HypSelectors } from '../hypervisor/hypervisor.selectors';\nimport { HypProcedureModel } from '../../model/procedure/hyp-procedure-model.interface';\nimport { ProcedureSelectors } from './procedure.selectors';\nimport { EventSelectors } from '../event/event.selectors';\nimport { FilterParamEncoder } from '@provoly/dashboard';\n\nexport const PROCEDURE_PAGE_SIZE_FETCH = { value: 20 };\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class ProcedureService {\n  constructor(\n    private httpClient: HttpClient,\n    private store: Store<any>\n  ) {}\n\n  list(startWith = 0, pageSize = PROCEDURE_PAGE_SIZE_FETCH.value): Observable<HypProcedureModel[]> {\n    return combineLatest([\n      this.store.select(HypSelectors.url),\n      this.store.select(ProcedureSelectors.sort),\n      this.store.select(EventSelectors.filters).pipe(map((filters) => filters['procedure'] ?? {}))\n    ]).pipe(\n      mergeMap(([url, sort, filters]) => {\n        let params = new HttpParams({ encoder: new FilterParamEncoder() });\n        Object.keys(filters).forEach((filter) => {\n          filters[filter].forEach((filterValue) => {\n            params = params.append(filter, filterValue);\n          });\n        });\n        params = params.set('page', startWith / pageSize + 1);\n\n        if (sort) params = params.set('sort', sort.field).set('order', sort.order);\n        return this.httpClient.get<HypProcedureModel[]>(encodeURI(`${url}/procedures/model`), { params });\n      })\n    );\n  }\n\n  getTop10ByUsage(domain?: string, search?: string): Observable<HypProcedureModel[]> {\n    return this.store.select(HypSelectors.url).pipe(\n      mergeMap((url) => {\n        let params = new HttpParams();\n\n        params = params.set('sort', 'useCount').set('order', 'DESC').set('pageSize', '10').set('active', 'true');\n        if (search) params = params.set('search', search);\n        if (domain) params = params.set('domain', domain);\n        return this.httpClient.get<HypProcedureModel[]>(encodeURI(`${url}/procedures/model`), { params });\n      })\n    );\n  }\n\n  get(id: number) {\n    return this.store.select(HypSelectors.url).pipe(\n      mergeMap((url) => {\n        return this.httpClient.get<HypProcedureModel>(encodeURI(`${url}/procedures/model/id/${id}`));\n      })\n    );\n  }\n\n  save(model: HypProcedureModel) {\n    return this.store.select(HypSelectors.url).pipe(\n      mergeMap((url) => {\n        if (!model.id) {\n          return this.httpClient.post<HypProcedureModel>(encodeURI(`${url}/procedures/model`), model);\n        }\n        return this.httpClient\n          .put<void>(encodeURI(`${url}/procedures/model/id/${model.id}`), model)\n          .pipe(map(() => model));\n      })\n    );\n  }\n\n  delete(id: number) {\n    return this.store.select(HypSelectors.url).pipe(\n      mergeMap((url) => {\n        return this.httpClient.delete<void>(encodeURI(`${url}/procedures/id/${id}`));\n      })\n    );\n  }\n}\n"]}
|