@provoly/hypervisor 2.1.0 → 2.1.9

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.
@@ -34,6 +34,8 @@ export class ProcedureAssociationModalComponent extends SubscriptionnerDirective
34
34
  this.eventsForAction = [];
35
35
  this.disableValidButton = true;
36
36
  this.eventsDomain = [];
37
+ this.modifyProcedure = false;
38
+ this.previousProcedureId = undefined;
37
39
  this.title = '@hvy.associationModal.title';
38
40
  this.DOMAINS = DOMAINS.values;
39
41
  this.padId = padId;
@@ -105,10 +107,22 @@ export class ProcedureAssociationModalComponent extends SubscriptionnerDirective
105
107
  this.onProcedureSearch$.next();
106
108
  }
107
109
  associateProcedure() {
108
- this.store.dispatch(EventActions.associateProcedure({
109
- procedureId: this.procedureSelectValue.id,
110
- eventIds: this.eventsForAction.map((event) => event.id)
111
- }));
110
+ if (this.modifyProcedure && this.previousProcedureId) {
111
+ this.procedureService.delete(this.previousProcedureId).subscribe(result => {
112
+ this.modifyProcedure = false;
113
+ this.previousProcedureId = undefined;
114
+ this.store.dispatch(EventActions.associateProcedure({
115
+ procedureId: this.procedureSelectValue.id,
116
+ eventIds: this.eventsForAction.map((event) => event.id)
117
+ }));
118
+ });
119
+ }
120
+ else {
121
+ this.store.dispatch(EventActions.associateProcedure({
122
+ procedureId: this.procedureSelectValue.id,
123
+ eventIds: this.eventsForAction.map((event) => event.id)
124
+ }));
125
+ }
112
126
  this.closeModal();
113
127
  }
114
128
  closeModal() {
@@ -129,4 +143,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImpor
129
143
  }], procedureDomain: [{
130
144
  type: Input
131
145
  }] } });
132
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"procedure-association-modal.component.js","sourceRoot":"","sources":["../../../../../../../../projects/provoly/hypervisor/src/lib/event/procedure-association-modal/procedure-association-modal.component.ts","../../../../../../../../projects/provoly/hypervisor/src/lib/event/procedure-association-modal/procedure-association-modal.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input } from '@angular/core';\nimport { BehaviorSubject, combineLatest, debounceTime, Observable, shareReplay, Subject, switchMap } from 'rxjs';\nimport { Store } from '@ngrx/store';\nimport { PryDialogRef, SubscriptionnerDirective } from '@provoly/dashboard';\nimport { EventActions } from '../../store/event/event.actions';\nimport { EventSelectors } from '../../store/event/event.selectors';\nimport { HypEventDetails } from '../../model/event/hyp-event-detail.interface';\nimport { HypProcedureModel } from '../../model/procedure/hyp-procedure-model.interface';\nimport { ProcedureService } from '../../store/procedure/procedure.service';\nimport { catchError, map, startWith } from 'rxjs/operators';\nimport { DOMAINS } from '../../model/domains.constant';\nimport { padId } from '../../general/pad-id.function';\n\nexport interface HypProcedureModelWithMatching extends HypProcedureModel {\n  initial: string;\n  html: string;\n}\n\n@Component({\n  selector: 'hvy-procedure-association-modal',\n  templateUrl: './procedure-association-modal.component.html'\n})\nexport class ProcedureAssociationModalComponent extends SubscriptionnerDirective {\n  selectedEvents$: Observable<HypEventDetails[]>;\n\n  selectedDomain?: string;\n  selectedProcedureInComboBox?: HypProcedureModel;\n  onDomainSelect$ = new BehaviorSubject<void>(undefined);\n\n  onProcedureSearch$ = new Subject<void>();\n  procedures$: Observable<HypProcedureModelWithMatching[]>;\n  eventsFromInput$ = new BehaviorSubject<HypEventDetails[] | null>(null);\n  eventsForAction: HypEventDetails[] = [];\n  disableValidButton = true;\n  eventsDomain: (string | undefined)[] = [];\n\n  @Input() set events(events: HypEventDetails[]) {\n    this.eventsFromInput$.next(events);\n  }\n\n  @Input() title: string = '@hvy.associationModal.title';\n  @Input() procedureSelectValue?: string | HypProcedureModel;\n  @Input() set procedureDomain(domain: string) {\n    if(domain && domain !== this.selectedDomain) {\n      this.selectedDomain = this.eventsDomain.length === 1 ? this.eventsDomain[0] : undefined;\n      this.procedureSelectValue = undefined;\n    }\n  }\n\n  constructor(\n    private store: Store,\n    private procedureService: ProcedureService,\n    private dialog: PryDialogRef<ProcedureAssociationModalComponent>\n  ) {\n    super();\n    this.selectedEvents$ = combineLatest([\n      this.eventsFromInput$,\n      this.store.select(EventSelectors.selectedEvents)\n    ]).pipe(\n      map(([eventsFromInput, eventsFromSelect]) => (eventsFromInput !== null ? eventsFromInput : eventsFromSelect))\n    );\n\n    this.subscriptions.add(this.selectedEvents$.subscribe((events) => (this.eventsForAction = events)));\n\n    this.subscriptions.add(\n      this.selectedEvents$.subscribe((events) => {\n        this.eventsDomain = [...new Set(events.map((ev) => ev.domain))];\n        if (this.eventsDomain.length === 1) {\n          this.selectedDomain = this.eventsDomain[0];\n        }\n      })\n    );\n\n    this.procedures$ = combineLatest([\n      this.onDomainSelect$.pipe(startWith()),\n      this.onProcedureSearch$.pipe(startWith(), debounceTime(500))\n    ]).pipe(\n      switchMap(([_, __]) => {\n        const search =\n          typeof this.procedureSelectValue === 'string' && this.procedureSelectValue.length > 2 ?\n            this.cleanProcedureNameForComboBoxSearch(this.procedureSelectValue) :\n              typeof this.procedureSelectValue === 'object' ?\n                this.procedureSelectValue.name :\n                  undefined;\n        return this.procedureService.getTop10ByUsage(this.selectedDomain, search).pipe(\n          map((procedures) =>\n            procedures.map((proc) => {\n              const regex = RegExp(`(${search})` ?? '(/-/-/)', 'gid');\n              const html = `${padId.fn(proc.id)} - ${proc.name} (${proc.creator})`;\n              return {\n                ...proc,\n                initial: html,\n                html: html.replaceAll(regex, (matched: string, capture1: string) => `<b>${capture1}</b>`)\n              } as HypProcedureModelWithMatching;\n            })\n          )\n        );\n      }),\n      catchError(() => {\n        throw new Error('Procedure catalog problem');\n      }),\n      shareReplay()\n    );\n  }\n\n  onDomainChange() {\n    this.onDomainSelect$.next();\n    this.procedureSelectValue = undefined;\n  }\n\n  cleanProcedureNameForComboBoxSearch(procedure: string){\n    const indexOfTiret = procedure.indexOf('-');\n    const indexOfCreator = procedure.lastIndexOf('(');\n    if(indexOfTiret !== -1 && indexOfCreator !== -1) {\n      procedure = procedure.substring(indexOfTiret + 2, indexOfCreator - 1);\n    } else if (indexOfTiret !== -1) {\n      procedure = procedure.substring(indexOfTiret + 2);\n    } else if(indexOfCreator !== -1) {\n      procedure = procedure.substring(0, indexOfCreator - 1);\n    }\n    return procedure;\n  }\n\n  selectedProcedureChange($event: string | HypProcedureModel) {\n    // when choose a procedure\n    if(typeof $event === 'object') {\n      this.selectedProcedureInComboBox = $event;\n      this.procedureSelectValue = $event;\n      // when click on choosen procedure\n    } else if((this.selectedProcedureInComboBox as HypProcedureModelWithMatching)?.html === $event) {\n        this.procedureSelectValue = this.selectedProcedureInComboBox;\n      } else {\n        this.procedureSelectValue = $event;\n      }\n    this.disableValidButton = typeof this.procedureSelectValue !== 'object';\n    this.onProcedureSearch$.next();\n  }\n\n  associateProcedure() {\n    this.store.dispatch(\n      EventActions.associateProcedure({\n        procedureId: (this.procedureSelectValue as HypProcedureModel).id,\n        eventIds: this.eventsForAction.map((event) => event.id)\n      })\n    );\n    this.closeModal();\n  }\n\n  closeModal() {\n    this.dialog.close();\n  }\n\n  protected readonly DOMAINS = DOMAINS.values;\n  protected readonly padId = padId;\n}\n","<div class=\"o-hvy-association-modal u-display-flex -column -align-center\">\n  <h3>{{ title | i18n }}</h3>\n  <span class=\"o-hvy-association-modal__description\">{{ '@hvy.associationModal.description' | i18n }}</span>\n  <div class=\"o-hvy-association-modal__content u-display-flex -justify-space-between\">\n    @if (selectedEvents$ | async; as selectedEvents) {\n      <div class=\"asso-eve\">\n        <label>Événements liés ({{ selectedEvents.length }}) :</label>\n        <ul class=\"o-hvy-association-modal__events\">\n          @for (event of selectedEvents; track event.id) {\n            <li class=\"o-hvy-association-modal__event u-display-flex -align-center\">\n              <hvy-icon-display [event]=\"event\"></hvy-icon-display>\n              <div class=\"o-hvy-association-modal__event-detail u-display-flex -column\">\n                <span class=\"o-hvy-association-modal__event-name\">{{ padId.fn(event.id) }} - {{ event.name }}</span>\n                @if (event.equipment) {\n                  <span class=\"o-hvy-association-modal__equipment-name\">{{ event.equipment.name }}</span>\n                }\n              </div>\n            </li>\n          }\n        </ul>\n      </div>\n    }\n    <div class=\"o-hvy-association-modal__form\">\n      <div class=\"m-form-label-field\">\n        <label>{{ '@hvy.associationModal.categoryFilter' | i18n }} :</label>\n        <pry-select\n          [items]=\"DOMAINS\"\n          [(ngModel)]=\"selectedDomain\"\n          (ngModelChange)=\"onDomainChange()\"\n          [placeholder]=\"'@hvy.associationModal.domainPlaceholder' | i18n\"\n          i18nPrefix=\"@hvy.event.domain.\"\n          id=\"category-filter\"\n        ></pry-select>\n      </div>\n      <div class=\"m-form-label-field\">\n        <label for=\"procedure-filter\"\n          >{{ '@hvy.associationModal.searchProcedure' | i18n }}<span class=\"text-error\">*</span> :\n        </label>\n        <pry-select\n          [items]=\"procedures$ | async\"\n          bindLabel=\"initial\"\n          [(ngModel)]=\"procedureSelectValue\"\n          (ngModelChange)=\"selectedProcedureChange($event)\"\n          [autocomplete]=\"true\"\n          [externalAutocompleteService]=\"true\"\n          [placeholder]=\"'@hvy.associationModal.procedurePlaceholder' | i18n\"\n          id=\"procedure-filter\"\n          [template]=\"templateOption\"\n        ></pry-select>\n        <ng-template #templateOption let-item=\"item\">\n          <div class=\"u-display-flex -column\">\n            <span [innerHTML]=\"item.html\"></span>\n          </div>\n        </ng-template>\n      </div>\n    </div>\n  </div>\n  <div class=\"o-hvy-association-modal__buttons u-display-flex -justify-center\">\n    <button class=\"a-btn a-btn--primary\" [disabled]=\"disableValidButton\" (click)=\"associateProcedure()\">\n      {{ '@hvy.action.validate' | i18n }}\n    </button>\n    <button class=\"a-btn a-btn--secondary\" (click)=\"closeModal()\">{{ '@hvy.action.cancel' | i18n }}</button>\n  </div>\n</div>\n"]}
146
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"procedure-association-modal.component.js","sourceRoot":"","sources":["../../../../../../../../projects/provoly/hypervisor/src/lib/event/procedure-association-modal/procedure-association-modal.component.ts","../../../../../../../../projects/provoly/hypervisor/src/lib/event/procedure-association-modal/procedure-association-modal.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input } from '@angular/core';\nimport { BehaviorSubject, combineLatest, debounceTime, Observable, shareReplay, Subject, switchMap } from 'rxjs';\nimport { Store } from '@ngrx/store';\nimport { PryDialogRef, SubscriptionnerDirective } from '@provoly/dashboard';\nimport { EventActions } from '../../store/event/event.actions';\nimport { EventSelectors } from '../../store/event/event.selectors';\nimport { HypEventDetails } from '../../model/event/hyp-event-detail.interface';\nimport { HypProcedureModel } from '../../model/procedure/hyp-procedure-model.interface';\nimport { ProcedureService } from '../../store/procedure/procedure.service';\nimport { catchError, map, startWith } from 'rxjs/operators';\nimport { DOMAINS } from '../../model/domains.constant';\nimport { padId } from '../../general/pad-id.function';\n\nexport interface HypProcedureModelWithMatching extends HypProcedureModel {\n  initial: string;\n  html: string;\n}\n\n@Component({\n  selector: 'hvy-procedure-association-modal',\n  templateUrl: './procedure-association-modal.component.html'\n})\nexport class ProcedureAssociationModalComponent extends SubscriptionnerDirective {\n  selectedEvents$: Observable<HypEventDetails[]>;\n\n  selectedDomain?: string;\n  selectedProcedureInComboBox?: HypProcedureModel;\n  onDomainSelect$ = new BehaviorSubject<void>(undefined);\n\n  onProcedureSearch$ = new Subject<void>();\n  procedures$: Observable<HypProcedureModelWithMatching[]>;\n  eventsFromInput$ = new BehaviorSubject<HypEventDetails[] | null>(null);\n  eventsForAction: HypEventDetails[] = [];\n  disableValidButton = true;\n  eventsDomain: (string | undefined)[] = [];\n  modifyProcedure = false;\n  previousProcedureId: number | undefined = undefined\n\n  @Input() set events(events: HypEventDetails[]) {\n    this.eventsFromInput$.next(events);\n  }\n\n  @Input() title: string = '@hvy.associationModal.title';\n  @Input() procedureSelectValue?: string | HypProcedureModel;\n  @Input() set procedureDomain(domain: string) {\n    if(domain && domain !== this.selectedDomain) {\n      this.selectedDomain = this.eventsDomain.length === 1 ? this.eventsDomain[0] : undefined;\n      this.procedureSelectValue = undefined;\n    }\n  }\n\n  constructor(\n    private store: Store,\n    private procedureService: ProcedureService,\n    private dialog: PryDialogRef<ProcedureAssociationModalComponent>\n  ) {\n    super();\n    this.selectedEvents$ = combineLatest([\n      this.eventsFromInput$,\n      this.store.select(EventSelectors.selectedEvents)\n    ]).pipe(\n      map(([eventsFromInput, eventsFromSelect]) => (eventsFromInput !== null ? eventsFromInput : eventsFromSelect))\n    );\n\n    this.subscriptions.add(this.selectedEvents$.subscribe((events) => (this.eventsForAction = events)));\n\n    this.subscriptions.add(\n      this.selectedEvents$.subscribe((events) => {\n        this.eventsDomain = [...new Set(events.map((ev) => ev.domain))];\n        if (this.eventsDomain.length === 1) {\n          this.selectedDomain = this.eventsDomain[0];\n        }\n      })\n    );\n\n    this.procedures$ = combineLatest([\n      this.onDomainSelect$.pipe(startWith()),\n      this.onProcedureSearch$.pipe(startWith(), debounceTime(500))\n    ]).pipe(\n      switchMap(([_, __]) => {\n        const search =\n          typeof this.procedureSelectValue === 'string' && this.procedureSelectValue.length > 2 ?\n            this.cleanProcedureNameForComboBoxSearch(this.procedureSelectValue) :\n              typeof this.procedureSelectValue === 'object' ?\n                this.procedureSelectValue.name :\n                  undefined;\n        return this.procedureService.getTop10ByUsage(this.selectedDomain, search).pipe(\n          map((procedures) =>\n            procedures.map((proc) => {\n              const regex = RegExp(`(${search})` ?? '(/-/-/)', 'gid');\n              const html = `${padId.fn(proc.id)} - ${proc.name} (${proc.creator})`;\n              return {\n                ...proc,\n                initial: html,\n                html: html.replaceAll(regex, (matched: string, capture1: string) => `<b>${capture1}</b>`)\n              } as HypProcedureModelWithMatching;\n            })\n          )\n        );\n      }),\n      catchError(() => {\n        throw new Error('Procedure catalog problem');\n      }),\n      shareReplay()\n    );\n  }\n\n  onDomainChange() {\n    this.onDomainSelect$.next();\n    this.procedureSelectValue = undefined;\n  }\n\n  cleanProcedureNameForComboBoxSearch(procedure: string){\n    const indexOfTiret = procedure.indexOf('-');\n    const indexOfCreator = procedure.lastIndexOf('(');\n    if(indexOfTiret !== -1 && indexOfCreator !== -1) {\n      procedure = procedure.substring(indexOfTiret + 2, indexOfCreator - 1);\n    } else if (indexOfTiret !== -1) {\n      procedure = procedure.substring(indexOfTiret + 2);\n    } else if(indexOfCreator !== -1) {\n      procedure = procedure.substring(0, indexOfCreator - 1);\n    }\n    return procedure;\n  }\n\n  selectedProcedureChange($event: string | HypProcedureModel) {\n    // when choose a procedure\n    if(typeof $event === 'object') {\n      this.selectedProcedureInComboBox = $event;\n      this.procedureSelectValue = $event;\n      // when click on choosen procedure\n    } else if((this.selectedProcedureInComboBox as HypProcedureModelWithMatching)?.html === $event) {\n        this.procedureSelectValue = this.selectedProcedureInComboBox;\n      } else {\n        this.procedureSelectValue = $event;\n      }\n    this.disableValidButton = typeof this.procedureSelectValue !== 'object';\n    this.onProcedureSearch$.next();\n  }\n\n  associateProcedure() {\n    if (this.modifyProcedure && this.previousProcedureId) {\n      this.procedureService.delete(this.previousProcedureId).subscribe(result => {\n        this.modifyProcedure = false;\n        this.previousProcedureId = undefined;\n        this.store.dispatch(\n          EventActions.associateProcedure({\n            procedureId: (this.procedureSelectValue as HypProcedureModel).id,\n            eventIds: this.eventsForAction.map((event) => event.id)\n          })\n        );\n      })\n    } else {\n      this.store.dispatch(\n        EventActions.associateProcedure({\n          procedureId: (this.procedureSelectValue as HypProcedureModel).id,\n          eventIds: this.eventsForAction.map((event) => event.id)\n        })\n      );\n    }\n    this.closeModal();\n  }\n\n  closeModal() {\n    this.dialog.close();\n  }\n\n  protected readonly DOMAINS = DOMAINS.values;\n  protected readonly padId = padId;\n}\n","<div class=\"o-hvy-association-modal u-display-flex -column -align-center\">\n  <h3>{{ title | i18n }}</h3>\n  <span class=\"o-hvy-association-modal__description\">{{ '@hvy.associationModal.description' | i18n }}</span>\n  <div class=\"o-hvy-association-modal__content u-display-flex -justify-space-between\">\n    @if (selectedEvents$ | async; as selectedEvents) {\n      <div class=\"asso-eve\">\n        <label>Événements liés ({{ selectedEvents.length }}) :</label>\n        <ul class=\"o-hvy-association-modal__events\">\n          @for (event of selectedEvents; track event.id) {\n            <li class=\"o-hvy-association-modal__event u-display-flex -align-center\">\n              <hvy-icon-display [event]=\"event\"></hvy-icon-display>\n              <div class=\"o-hvy-association-modal__event-detail u-display-flex -column\">\n                <span class=\"o-hvy-association-modal__event-name\">{{ padId.fn(event.id) }} - {{ event.name }}</span>\n                @if (event.equipment) {\n                  <span class=\"o-hvy-association-modal__equipment-name\">{{ event.equipment.name }}</span>\n                }\n              </div>\n            </li>\n          }\n        </ul>\n      </div>\n    }\n    <div class=\"o-hvy-association-modal__form\">\n      <div class=\"m-form-label-field\">\n        <label>{{ '@hvy.associationModal.categoryFilter' | i18n }} :</label>\n        <pry-select\n          [items]=\"DOMAINS\"\n          [(ngModel)]=\"selectedDomain\"\n          (ngModelChange)=\"onDomainChange()\"\n          [placeholder]=\"'@hvy.associationModal.domainPlaceholder' | i18n\"\n          i18nPrefix=\"@hvy.event.domain.\"\n          id=\"category-filter\"\n        ></pry-select>\n      </div>\n      <div class=\"m-form-label-field\">\n        <label for=\"procedure-filter\"\n          >{{ '@hvy.associationModal.searchProcedure' | i18n }}<span class=\"text-error\">*</span> :\n        </label>\n        <pry-select\n          [items]=\"procedures$ | async\"\n          bindLabel=\"initial\"\n          [(ngModel)]=\"procedureSelectValue\"\n          (ngModelChange)=\"selectedProcedureChange($event)\"\n          [autocomplete]=\"true\"\n          [externalAutocompleteService]=\"true\"\n          [placeholder]=\"'@hvy.associationModal.procedurePlaceholder' | i18n\"\n          id=\"procedure-filter\"\n          [template]=\"templateOption\"\n        ></pry-select>\n        <ng-template #templateOption let-item=\"item\">\n          <div class=\"u-display-flex -column\">\n            <span [innerHTML]=\"item.html\"></span>\n          </div>\n        </ng-template>\n      </div>\n    </div>\n  </div>\n  <div class=\"o-hvy-association-modal__buttons u-display-flex -justify-center\">\n    <button class=\"a-btn a-btn--primary\" [disabled]=\"disableValidButton\" (click)=\"associateProcedure()\">\n      {{ '@hvy.action.validate' | i18n }}\n    </button>\n    <button class=\"a-btn a-btn--secondary\" (click)=\"closeModal()\">{{ '@hvy.action.cancel' | i18n }}</button>\n  </div>\n</div>\n"]}
@@ -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></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
+ 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\"><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", 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" }] }); }
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></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
+ 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\"><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" }]
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,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"]}
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"]}