@loxia/mst-viewer 8.1.3-202512020726 → 8.1.3-202512030346

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.
Files changed (135) hide show
  1. package/esm2022/generated/openapi/api/api.mjs +23 -0
  2. package/esm2022/generated/openapi/api/appConfigController.service.mjs +140 -0
  3. package/esm2022/generated/openapi/api/appConfigController.serviceInterface.mjs +2 -0
  4. package/esm2022/generated/openapi/api/bewegingController.service.mjs +155 -0
  5. package/esm2022/generated/openapi/api/bewegingController.serviceInterface.mjs +2 -0
  6. package/esm2022/generated/openapi/api/class0BuildProperties.service.mjs +140 -0
  7. package/esm2022/generated/openapi/api/class0BuildProperties.serviceInterface.mjs +2 -0
  8. package/esm2022/generated/openapi/api/connectorController.service.mjs +146 -0
  9. package/esm2022/generated/openapi/api/connectorController.serviceInterface.mjs +2 -0
  10. package/esm2022/generated/openapi/api/logController.service.mjs +150 -0
  11. package/esm2022/generated/openapi/api/logController.serviceInterface.mjs +2 -0
  12. package/esm2022/generated/openapi/api/p21Controller.service.mjs +236 -0
  13. package/esm2022/generated/openapi/api/p21Controller.serviceInterface.mjs +2 -0
  14. package/esm2022/generated/openapi/api/sbController.service.mjs +202 -0
  15. package/esm2022/generated/openapi/api/sbController.serviceInterface.mjs +2 -0
  16. package/esm2022/generated/openapi/api.module.mjs +40 -0
  17. package/esm2022/generated/openapi/configuration.mjs +99 -0
  18. package/esm2022/generated/openapi/encoder.mjs +19 -0
  19. package/esm2022/generated/openapi/index.mjs +7 -0
  20. package/esm2022/generated/openapi/model/actieDto.mjs +13 -0
  21. package/esm2022/generated/openapi/model/algemeneRitDto.mjs +13 -0
  22. package/esm2022/generated/openapi/model/bewegingDto.mjs +2 -0
  23. package/esm2022/generated/openapi/model/frontendKeycloakConfig.mjs +13 -0
  24. package/esm2022/generated/openapi/model/frontendProperties.mjs +2 -0
  25. package/esm2022/generated/openapi/model/logDto.mjs +2 -0
  26. package/esm2022/generated/openapi/model/models.mjs +10 -0
  27. package/esm2022/generated/openapi/model/ritRequestDto.mjs +2 -0
  28. package/esm2022/generated/openapi/model/signaleringsbeeldDto.mjs +13 -0
  29. package/esm2022/generated/openapi/model/signaleringsbeeldRequestDto.mjs +13 -0
  30. package/esm2022/generated/openapi/param.mjs +2 -0
  31. package/esm2022/generated/openapi/variables.mjs +9 -0
  32. package/esm2022/generated.version.mjs +2 -0
  33. package/esm2022/lib/atomic-components/message/index.mjs +4 -0
  34. package/esm2022/lib/atomic-components/message/message.component.mjs +34 -0
  35. package/esm2022/lib/atomic-components/message/message.mjs +8 -0
  36. package/esm2022/lib/atomic-components/message/severity.enum.mjs +9 -0
  37. package/esm2022/lib/atomic-components/messages/messages.component.mjs +20 -0
  38. package/esm2022/lib/atomic-components/overlay/overlay.component.mjs +11 -0
  39. package/esm2022/lib/atomic-components/progress-indicator/progress-indicator.component.mjs +11 -0
  40. package/esm2022/lib/atomic-components/progress-indicator/progress-indicator.entity.mjs +8 -0
  41. package/esm2022/lib/atomic-components/services/messages.service.mjs +27 -0
  42. package/esm2022/lib/components/carousel-controls/carousel-controls.component.mjs +40 -0
  43. package/esm2022/lib/components/mstviewer/mstviewer.component.mjs +110 -0
  44. package/esm2022/lib/components/ritdelen-lijst/ritdelen-lijst.component.mjs +267 -0
  45. package/esm2022/lib/components/ritdelen-view/ritdelen-view.component.mjs +103 -0
  46. package/esm2022/lib/components/rpe/rpe.component.mjs +33 -0
  47. package/esm2022/lib/components/svg-visualisatie/svg-visualisatie.component.mjs +273 -0
  48. package/esm2022/lib/components/viewer-controls/viewer-controls.component.mjs +52 -0
  49. package/esm2022/lib/model/alternatief-rit-deel.mjs +7 -0
  50. package/esm2022/lib/model/km-range.mjs +39 -0
  51. package/esm2022/lib/model/melding-event.mjs +7 -0
  52. package/esm2022/lib/model/nieuwe-route.mjs +10 -0
  53. package/esm2022/lib/model/ongeplande-actie.mjs +7 -0
  54. package/esm2022/lib/model/rijwegplan-rijweg-dwang-combinatie.mjs +24 -0
  55. package/esm2022/lib/model/ritdeel.mjs +205 -0
  56. package/esm2022/lib/model/sein-op-ritdeel.mjs +7 -0
  57. package/esm2022/lib/model/wissel-kant-code.mjs +7 -0
  58. package/esm2022/lib/mst-viewer.module.mjs +143 -0
  59. package/esm2022/lib/optimo.mjs +9 -0
  60. package/esm2022/lib/resources/mstlogging.resource.mjs +25 -0
  61. package/esm2022/lib/resources/signaleringsbeeldinfo.resource.mjs +62 -0
  62. package/esm2022/lib/services/base-rest.service.mjs +26 -0
  63. package/esm2022/lib/services/beweging-utils.service.mjs +139 -0
  64. package/esm2022/lib/services/beweging-verrijker.service.mjs +30 -0
  65. package/esm2022/lib/services/connector.service.mjs +30 -0
  66. package/esm2022/lib/services/debug.service.mjs +59 -0
  67. package/esm2022/lib/services/editor.service.mjs +48 -0
  68. package/esm2022/lib/services/print-beweging.service.mjs +66 -0
  69. package/esm2022/lib/services/rit-lezer.service.mjs +104 -0
  70. package/esm2022/lib/services/signalerings-beeld-manager.service.mjs +92 -0
  71. package/esm2022/lib/services/viewer-control.service.mjs +104 -0
  72. package/esm2022/lib/state/actions/actions.mjs +130 -0
  73. package/esm2022/lib/state/actions/ritdelen.actions.mjs +45 -0
  74. package/esm2022/lib/state/effect/bepaal-ongeplande-acties.effect.mjs +78 -0
  75. package/esm2022/lib/state/effect/bepaal-sb-infos.effect.mjs +67 -0
  76. package/esm2022/lib/state/effect/beweging-invoegen.effect.mjs +73 -0
  77. package/esm2022/lib/state/effect/delete-ongeplande-actie.effect.mjs +39 -0
  78. package/esm2022/lib/state/effect/focus-effect.mjs +36 -0
  79. package/esm2022/lib/state/effect/laad-route-files.effect.mjs +64 -0
  80. package/esm2022/lib/state/effect/laad-signaleringsbeelden.effect.mjs +363 -0
  81. package/esm2022/lib/state/effect/rit-goedkeuren.effect.mjs +23 -0
  82. package/esm2022/lib/state/effect/ritdelen.effect.mjs +112 -0
  83. package/esm2022/lib/state/effect/svg-view.effect.mjs +48 -0
  84. package/esm2022/lib/state/mst-editor-state.mjs +89 -0
  85. package/esm2022/lib/state/reducer/rit-delen.reducer.mjs +62 -0
  86. package/esm2022/lib/util/actie-helper.mjs +437 -0
  87. package/esm2022/lib/util/actie-popover-bepaler.mjs +90 -0
  88. package/esm2022/lib/util/date.service.mjs +17 -0
  89. package/esm2022/lib/util/logging-helper.mjs +58 -0
  90. package/esm2022/lib/util/melding-builder.mjs +13 -0
  91. package/esm2022/lib/util/message-builder.mjs +32 -0
  92. package/esm2022/lib/util/multi-map.mjs +76 -0
  93. package/esm2022/lib/util/utils.mjs +35 -0
  94. package/esm2022/lib/util/zone-util.mjs +32 -0
  95. package/esm2022/loxia-mst-viewer.mjs +5 -0
  96. package/esm2022/public-api.mjs +9 -0
  97. package/esm2022/src/generated/openapi/api/api.mjs +23 -0
  98. package/esm2022/src/generated/openapi/api/appConfigController.service.mjs +140 -0
  99. package/esm2022/src/generated/openapi/api/appConfigController.serviceInterface.mjs +2 -0
  100. package/esm2022/src/generated/openapi/api/bewegingController.service.mjs +155 -0
  101. package/esm2022/src/generated/openapi/api/bewegingController.serviceInterface.mjs +2 -0
  102. package/esm2022/src/generated/openapi/api/class0BuildProperties.service.mjs +140 -0
  103. package/esm2022/src/generated/openapi/api/class0BuildProperties.serviceInterface.mjs +2 -0
  104. package/esm2022/src/generated/openapi/api/connectorController.service.mjs +146 -0
  105. package/esm2022/src/generated/openapi/api/connectorController.serviceInterface.mjs +2 -0
  106. package/esm2022/src/generated/openapi/api/logController.service.mjs +150 -0
  107. package/esm2022/src/generated/openapi/api/logController.serviceInterface.mjs +2 -0
  108. package/esm2022/src/generated/openapi/api/p21Controller.service.mjs +236 -0
  109. package/esm2022/src/generated/openapi/api/p21Controller.serviceInterface.mjs +2 -0
  110. package/esm2022/src/generated/openapi/api/sbController.service.mjs +202 -0
  111. package/esm2022/src/generated/openapi/api/sbController.serviceInterface.mjs +2 -0
  112. package/esm2022/src/generated/openapi/api.module.mjs +40 -0
  113. package/esm2022/src/generated/openapi/configuration.mjs +99 -0
  114. package/esm2022/src/generated/openapi/encoder.mjs +19 -0
  115. package/esm2022/src/generated/openapi/index.mjs +7 -0
  116. package/esm2022/src/generated/openapi/loxia-mst-viewer-src-generated-openapi.mjs +5 -0
  117. package/esm2022/src/generated/openapi/model/actieDto.mjs +13 -0
  118. package/esm2022/src/generated/openapi/model/algemeneRitDto.mjs +13 -0
  119. package/esm2022/src/generated/openapi/model/bewegingDto.mjs +2 -0
  120. package/esm2022/src/generated/openapi/model/frontendKeycloakConfig.mjs +13 -0
  121. package/esm2022/src/generated/openapi/model/frontendProperties.mjs +2 -0
  122. package/esm2022/src/generated/openapi/model/logDto.mjs +2 -0
  123. package/esm2022/src/generated/openapi/model/models.mjs +10 -0
  124. package/esm2022/src/generated/openapi/model/ritRequestDto.mjs +2 -0
  125. package/esm2022/src/generated/openapi/model/signaleringsbeeldDto.mjs +13 -0
  126. package/esm2022/src/generated/openapi/model/signaleringsbeeldRequestDto.mjs +13 -0
  127. package/esm2022/src/generated/openapi/param.mjs +2 -0
  128. package/esm2022/src/generated/openapi/variables.mjs +9 -0
  129. package/fesm2022/loxia-mst-viewer-src-generated-openapi.mjs +25 -25
  130. package/fesm2022/loxia-mst-viewer-src-generated-openapi.mjs.map +1 -1
  131. package/fesm2022/loxia-mst-viewer.mjs +154 -154
  132. package/fesm2022/loxia-mst-viewer.mjs.map +1 -1
  133. package/lib/atomic-components/overlay/overlay.component.d.ts +1 -1
  134. package/package.json +10 -6
  135. package/tailwind.scss +1 -1
@@ -0,0 +1,110 @@
1
+ import { Component, EventEmitter, Input, Output } from '@angular/core';
2
+ import { select } from '@ngrx/store';
3
+ import { Subscription } from 'rxjs';
4
+ import { version } from '../../../generated.version';
5
+ import * as MstActions from '../../state/actions/actions';
6
+ import { SetBaseUrl, SetIaVersie, SetOngeplandeActiesBepaald } from '../../state/actions/actions';
7
+ import { setRitdelenAfterUpdate } from '../../state/actions/ritdelen.actions';
8
+ import * as i0 from "@angular/core";
9
+ import * as i1 from "@ngrx/store";
10
+ import * as i2 from "../../services/viewer-control.service";
11
+ import * as i3 from "../../services/debug.service";
12
+ import * as i4 from "../../services/print-beweging.service";
13
+ import * as i5 from "@angular/common";
14
+ import * as i6 from "../../atomic-components/overlay/overlay.component";
15
+ import * as i7 from "../../atomic-components/progress-indicator/progress-indicator.component";
16
+ import * as i8 from "../rpe/rpe.component";
17
+ import * as i9 from "../ritdelen-lijst/ritdelen-lijst.component";
18
+ import * as i10 from "../ritdelen-view/ritdelen-view.component";
19
+ import * as i11 from "../viewer-controls/viewer-controls.component";
20
+ import * as i12 from "../svg-visualisatie/svg-visualisatie.component";
21
+ import * as i13 from "../../atomic-components/messages/messages.component";
22
+ export class MstviewerComponent {
23
+ constructor(store, viewerControlsService, debugService, printBewegingService) {
24
+ this.store = store;
25
+ this.viewerControlsService = viewerControlsService;
26
+ this.debugService = debugService;
27
+ this.printBewegingService = printBewegingService;
28
+ this.paginationSize = 4;
29
+ this.baseurl = 'https://acceptatie.raildesign.nl';
30
+ this.goedgekeurd = new EventEmitter();
31
+ this.subscriptions = new Subscription();
32
+ this.subscriptions.add(this.store.select('nieuweBewegingen').subscribe(nieuweRit => {
33
+ if (this.treinpad) {
34
+ this.treinpad.bewegingen = nieuweRit;
35
+ store.dispatch(setRitdelenAfterUpdate([]));
36
+ store.dispatch(SetOngeplandeActiesBepaald(false));
37
+ this.bepaalSbInfos(true);
38
+ }
39
+ }));
40
+ this.progressIndicator$ = this.store.pipe(select(s => s.progressState?.progressIndicator));
41
+ }
42
+ ngOnInit() {
43
+ // eslint-disable-next-line no-console
44
+ console.log('MST viewer versie: ' + version);
45
+ }
46
+ ngOnChanges({ debug, baseurl, treinpad, ongeplandeActies, iaversieinfo }) {
47
+ if (debug) {
48
+ this.debugService.setDebugFlag(debug.currentValue);
49
+ }
50
+ if (baseurl) {
51
+ this.store.dispatch(SetBaseUrl(baseurl.currentValue));
52
+ }
53
+ if (treinpad || ongeplandeActies) {
54
+ this.bepaalSbInfos();
55
+ }
56
+ if (iaversieinfo) {
57
+ this.store.dispatch(SetIaVersie(iaversieinfo.currentValue));
58
+ this.bepaalSbInfos();
59
+ }
60
+ if (ongeplandeActies) {
61
+ this.store.dispatch(SetOngeplandeActiesBepaald(false));
62
+ }
63
+ }
64
+ ngOnDestroy() {
65
+ this.debugService.setDebugFlag(false);
66
+ this.subscriptions.unsubscribe();
67
+ }
68
+ focusRitdeel(ritdeel) {
69
+ this.store.dispatch(MstActions.focusOpRitdeel(ritdeel, this.paginationSize, this.iaversieinfo));
70
+ }
71
+ focusPuic(puics) {
72
+ this.store.dispatch(MstActions.focusOpIds(puics));
73
+ }
74
+ bepaalSbInfos(ritGewijzigdToegestaan = false) {
75
+ if (this.treinpad && this.ongeplandeActies && this.iaversieinfo?.versie) {
76
+ this.store.dispatch(MstActions.bepaalSbInfos(this.treinpad, this.ongeplandeActies, this.iaversieinfo?.versie, ritGewijzigdToegestaan, this.paginationSize));
77
+ }
78
+ }
79
+ printFocusBeweging(bewegingId) {
80
+ return this.printBewegingService.printBeweging(bewegingId, this.paginationSize, this.iaversieinfo);
81
+ }
82
+ keurAlleActiesGoed() {
83
+ this.viewerControlsService.keurAlleActiesGoed(this.ongeplandeActies);
84
+ }
85
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: MstviewerComponent, deps: [{ token: i1.Store }, { token: i2.ViewerControlService }, { token: i3.DebugService }, { token: i4.PrintBewegingService }], target: i0.ɵɵFactoryTarget.Component }); }
86
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.7", type: MstviewerComponent, selector: "mst-viewer", inputs: { iaversieinfo: "iaversieinfo", treinpad: "treinpad", ongeplandeActies: "ongeplandeActies", paginationSize: "paginationSize", baseurl: "baseurl", debug: "debug", viewer: "viewer", useClickArea: "useClickArea" }, outputs: { goedgekeurd: "goedgekeurd" }, usesOnChanges: true, ngImport: i0, template: "<loxia-messages></loxia-messages>\n<loxia-overlay *ngIf=\"(progressIndicator$ | async)\">\n <loxia-progress-indicator id=\"progress-indicator\" [border]=\"false\" upperText=\"\">\n </loxia-progress-indicator>\n</loxia-overlay>\n\n<div style=\"position: relative\">\n <rpe-component [baseurl]=\"baseurl\" path=\"/mst/editor/editor.nocache.js\"></rpe-component>\n\n <svg-visualisatie [useClickArea]=\"useClickArea\" [nietGeplandeActies]=\"ongeplandeActies\"></svg-visualisatie>\n\n <nav [class.active]=\"(viewerControlsService.sideNavOpen$ | async) === false\" id=\"sidebar\">\n <div id=\"dismiss\">\n <em id=\"verbergSideNav\" class=\"fa fa-arrow-left\" (click)=\"viewerControlsService.toggleSideNavVisible()\">&times;</em>\n </div>\n <ritdelen-lijst *ngIf=\"!viewer\" (focusEmitter)=\"focusRitdeel($event)\" (keurAlleActiesGoed)=\"keurAlleActiesGoed()\"\n [nietGeplandeActies]=\"ongeplandeActies\"></ritdelen-lijst>\n <ritdelen-view *ngIf=\"viewer\" (focusEmitter)=\"focusRitdeel($event)\"></ritdelen-view>\n </nav>\n\n <viewer-controls [paginationSize]=\"paginationSize\"\n [iaversieinfo]=\"iaversieinfo\"\n [treinpad]=\"treinpad\"\n [goedgekeurd]=\"goedgekeurd\"\n ></viewer-controls>\n\n</div>\n", styles: ["#sidebar{min-width:350px;max-width:475px;background:#fff;transition:all .3s;height:93vh;position:absolute;top:0;z-index:20}#sidebar.active{margin-left:-475px}#sidebar .sidebar-header{padding:20px;background:#6d7fcc}#dismiss{width:20px;height:20px;position:absolute;cursor:pointer;top:5px;right:0;color:#000;z-index:300}[hidden]{display:none}\n"], dependencies: [{ kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i6.OverlayComponent, selector: "loxia-overlay" }, { kind: "component", type: i7.ProgressIndicatorComponent, selector: "loxia-progress-indicator" }, { kind: "component", type: i8.RpeComponent, selector: "rpe-component", inputs: ["baseurl", "path"] }, { kind: "component", type: i9.RitdelenLijstComponent, selector: "ritdelen-lijst", inputs: ["nietGeplandeActies"], outputs: ["focusEmitter", "keurAlleActiesGoed"] }, { kind: "component", type: i10.RitdelenViewComponent, selector: "ritdelen-view", outputs: ["focusEmitter"] }, { kind: "component", type: i11.ViewerControlsComponent, selector: "viewer-controls", inputs: ["paginationSize", "iaversieinfo", "treinpad", "goedgekeurd"] }, { kind: "component", type: i12.SvgVisualisatieComponent, selector: "svg-visualisatie", inputs: ["nietGeplandeActies", "useClickArea"] }, { kind: "component", type: i13.MessagesComponent, selector: "loxia-messages" }, { kind: "pipe", type: i5.AsyncPipe, name: "async" }] }); }
87
+ }
88
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: MstviewerComponent, decorators: [{
89
+ type: Component,
90
+ args: [{ selector: 'mst-viewer', template: "<loxia-messages></loxia-messages>\n<loxia-overlay *ngIf=\"(progressIndicator$ | async)\">\n <loxia-progress-indicator id=\"progress-indicator\" [border]=\"false\" upperText=\"\">\n </loxia-progress-indicator>\n</loxia-overlay>\n\n<div style=\"position: relative\">\n <rpe-component [baseurl]=\"baseurl\" path=\"/mst/editor/editor.nocache.js\"></rpe-component>\n\n <svg-visualisatie [useClickArea]=\"useClickArea\" [nietGeplandeActies]=\"ongeplandeActies\"></svg-visualisatie>\n\n <nav [class.active]=\"(viewerControlsService.sideNavOpen$ | async) === false\" id=\"sidebar\">\n <div id=\"dismiss\">\n <em id=\"verbergSideNav\" class=\"fa fa-arrow-left\" (click)=\"viewerControlsService.toggleSideNavVisible()\">&times;</em>\n </div>\n <ritdelen-lijst *ngIf=\"!viewer\" (focusEmitter)=\"focusRitdeel($event)\" (keurAlleActiesGoed)=\"keurAlleActiesGoed()\"\n [nietGeplandeActies]=\"ongeplandeActies\"></ritdelen-lijst>\n <ritdelen-view *ngIf=\"viewer\" (focusEmitter)=\"focusRitdeel($event)\"></ritdelen-view>\n </nav>\n\n <viewer-controls [paginationSize]=\"paginationSize\"\n [iaversieinfo]=\"iaversieinfo\"\n [treinpad]=\"treinpad\"\n [goedgekeurd]=\"goedgekeurd\"\n ></viewer-controls>\n\n</div>\n", styles: ["#sidebar{min-width:350px;max-width:475px;background:#fff;transition:all .3s;height:93vh;position:absolute;top:0;z-index:20}#sidebar.active{margin-left:-475px}#sidebar .sidebar-header{padding:20px;background:#6d7fcc}#dismiss{width:20px;height:20px;position:absolute;cursor:pointer;top:5px;right:0;color:#000;z-index:300}[hidden]{display:none}\n"] }]
91
+ }], ctorParameters: () => [{ type: i1.Store }, { type: i2.ViewerControlService }, { type: i3.DebugService }, { type: i4.PrintBewegingService }], propDecorators: { iaversieinfo: [{
92
+ type: Input
93
+ }], treinpad: [{
94
+ type: Input
95
+ }], ongeplandeActies: [{
96
+ type: Input
97
+ }], paginationSize: [{
98
+ type: Input
99
+ }], baseurl: [{
100
+ type: Input
101
+ }], debug: [{
102
+ type: Input
103
+ }], viewer: [{
104
+ type: Input
105
+ }], useClickArea: [{
106
+ type: Input
107
+ }], goedgekeurd: [{
108
+ type: Output
109
+ }] } });
110
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mstviewer.component.js","sourceRoot":"","sources":["../../../../../../projects/mst-viewer/src/lib/components/mstviewer/mstviewer.component.ts","../../../../../../projects/mst-viewer/src/lib/components/mstviewer/mstviewer.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnChanges, OnDestroy, OnInit, Output, SimpleChanges } from '@angular/core';\nimport { select, Store } from '@ngrx/store';\nimport { Observable, Subscription } from 'rxjs';\nimport { version } from '../../../generated.version';\nimport { ProgressIndicator } from '../../atomic-components/progress-indicator/progress-indicator.entity';\nimport { Ritdeel } from '../../model/ritdeel';\nimport { Actie, InfraModel, Rit } from '../../optimo';\nimport { DebugService } from '../../services/debug.service';\nimport { PrintBewegingService } from '../../services/print-beweging.service';\nimport { ViewerControlService } from '../../services/viewer-control.service';\nimport * as MstActions from '../../state/actions/actions';\nimport { SetBaseUrl, SetIaVersie, SetOngeplandeActiesBepaald } from '../../state/actions/actions';\nimport { setRitdelenAfterUpdate } from '../../state/actions/ritdelen.actions';\nimport { MstEditorState } from '../../state/mst-editor-state';\n\n@Component({\n    selector: 'mst-viewer',\n    templateUrl: './mstviewer.component.html',\n    styleUrls: ['./mstviewer.component.scss']\n})\nexport class MstviewerComponent implements OnChanges, OnInit, OnDestroy {\n    @Input() iaversieinfo: InfraModel;\n    @Input() treinpad: Rit;\n    @Input() ongeplandeActies: Actie[];\n    @Input() paginationSize = 4;\n    @Input() baseurl = 'https://acceptatie.raildesign.nl';\n    @Input() debug: boolean;\n    @Input() viewer: boolean;\n    @Input() useClickArea: boolean;\n\n    @Output() goedgekeurd: EventEmitter<Rit> = new EventEmitter();\n\n    progressIndicator$: Observable<ProgressIndicator>;\n\n    private subscriptions: Subscription = new Subscription();\n\n    constructor(private store: Store<MstEditorState>,\n                public viewerControlsService: ViewerControlService,\n                private debugService: DebugService,\n                private printBewegingService: PrintBewegingService) {\n\n        this.subscriptions.add(this.store.select('nieuweBewegingen').subscribe(nieuweRit => {\n            if (this.treinpad) {\n                this.treinpad.bewegingen = nieuweRit;\n                store.dispatch(setRitdelenAfterUpdate([]));\n                store.dispatch(SetOngeplandeActiesBepaald(false));\n                this.bepaalSbInfos(true);\n            }\n        }));\n        this.progressIndicator$ = this.store.pipe(select(s => s.progressState?.progressIndicator));\n    }\n\n    ngOnInit(): void {\n        // eslint-disable-next-line no-console\n        console.log('MST viewer versie: ' + version);\n    }\n\n    ngOnChanges({ debug, baseurl, treinpad, ongeplandeActies, iaversieinfo }: SimpleChanges): void {\n        if (debug) {\n            this.debugService.setDebugFlag(debug.currentValue);\n        }\n        if (baseurl) {\n            this.store.dispatch(SetBaseUrl(baseurl.currentValue));\n        }\n        if (treinpad || ongeplandeActies) {\n            this.bepaalSbInfos();\n        }\n        if (iaversieinfo) {\n            this.store.dispatch(SetIaVersie(iaversieinfo.currentValue));\n            this.bepaalSbInfos();\n        }\n        if (ongeplandeActies) {\n            this.store.dispatch(SetOngeplandeActiesBepaald(false));\n        }\n    }\n\n    ngOnDestroy(): void {\n        this.debugService.setDebugFlag(false);\n        this.subscriptions.unsubscribe();\n    }\n\n    focusRitdeel(ritdeel: Ritdeel): void {\n        this.store.dispatch(MstActions.focusOpRitdeel(ritdeel, this.paginationSize, this.iaversieinfo));\n    }\n\n    focusPuic(puics: string[]): void {\n        this.store.dispatch(MstActions.focusOpIds(puics));\n    }\n\n    bepaalSbInfos(ritGewijzigdToegestaan = false): void {\n        if (this.treinpad && this.ongeplandeActies && this.iaversieinfo?.versie) {\n            this.store.dispatch(MstActions.bepaalSbInfos(this.treinpad, this.ongeplandeActies, this.iaversieinfo?.versie, ritGewijzigdToegestaan, this.paginationSize));\n        }\n    }\n\n    printFocusBeweging(bewegingId: number): Promise<boolean> {\n        return this.printBewegingService.printBeweging(bewegingId, this.paginationSize, this.iaversieinfo);\n    }\n\n    keurAlleActiesGoed(): void {\n        this.viewerControlsService.keurAlleActiesGoed(this.ongeplandeActies);\n    }\n}\n","<loxia-messages></loxia-messages>\n<loxia-overlay *ngIf=\"(progressIndicator$ | async)\">\n    <loxia-progress-indicator id=\"progress-indicator\" [border]=\"false\" upperText=\"\">\n    </loxia-progress-indicator>\n</loxia-overlay>\n\n<div style=\"position: relative\">\n    <rpe-component [baseurl]=\"baseurl\" path=\"/mst/editor/editor.nocache.js\"></rpe-component>\n\n    <svg-visualisatie [useClickArea]=\"useClickArea\" [nietGeplandeActies]=\"ongeplandeActies\"></svg-visualisatie>\n\n    <nav [class.active]=\"(viewerControlsService.sideNavOpen$ | async) === false\" id=\"sidebar\">\n        <div id=\"dismiss\">\n            <em id=\"verbergSideNav\" class=\"fa fa-arrow-left\" (click)=\"viewerControlsService.toggleSideNavVisible()\">&times;</em>\n        </div>\n        <ritdelen-lijst *ngIf=\"!viewer\" (focusEmitter)=\"focusRitdeel($event)\" (keurAlleActiesGoed)=\"keurAlleActiesGoed()\"\n                        [nietGeplandeActies]=\"ongeplandeActies\"></ritdelen-lijst>\n        <ritdelen-view *ngIf=\"viewer\" (focusEmitter)=\"focusRitdeel($event)\"></ritdelen-view>\n    </nav>\n\n    <viewer-controls [paginationSize]=\"paginationSize\"\n                     [iaversieinfo]=\"iaversieinfo\"\n                     [treinpad]=\"treinpad\"\n                     [goedgekeurd]=\"goedgekeurd\"\n    ></viewer-controls>\n\n</div>\n"]}
@@ -0,0 +1,267 @@
1
+ import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from '@angular/core';
2
+ import { JsJavaUtil } from '@loxia/rijwegen';
3
+ import { combineLatest } from 'rxjs';
4
+ import { filter } from 'rxjs/operators';
5
+ import { OngeplandeActie } from '../../model/ongeplande-actie';
6
+ import * as MstActions from '../../state/actions/actions';
7
+ import * as RitdelenActions from '../../state/actions/ritdelen.actions';
8
+ import { ActieHelper } from '../../util/actie-helper';
9
+ import * as i0 from "@angular/core";
10
+ import * as i1 from "@ngrx/store";
11
+ import * as i2 from "../../services/signalerings-beeld-manager.service";
12
+ import * as i3 from "@angular/common";
13
+ export class RitdelenLijstComponent {
14
+ constructor(store, sbmService) {
15
+ this.store = store;
16
+ this.sbmService = sbmService;
17
+ this.focusEmitter = new EventEmitter();
18
+ this.keurAlleActiesGoed = new EventEmitter();
19
+ this.selectedRitdeelActies = [];
20
+ this.selectedRitdeelOngeplandeActies = [];
21
+ this.NG_ACTIE_PREFIX = '* ';
22
+ this.subscriptions = [];
23
+ this.subscriptions.push(store.select('ritDelen').subscribe((ritdelen) => {
24
+ this.ritdeelViewModels = ritdelen?.map(ritdeel => {
25
+ return new RitdeelViewModel(ritdeel, this.selectedRitdeelClass(ritdeel), this.isRitdeelZichtbaar(ritdeel), this.getTitle(ritdeel), ritdeel.isNietBeschikbaar(), this.isRitdeelNieuw(ritdeel), ritdeel.getVanPrlSpoor(), ritdeel.getNaarPrlSpoorText(), ritdeel.getDwangNummer(), ritdeel.getPplgString(), this.getTreinNummer(ritdeel));
26
+ });
27
+ }));
28
+ this.subscriptions.push(store.select('ongeplandeActies').subscribe(acties => this.ongeplandeActiesMap = acties));
29
+ this.subscriptions.push(store.select('geplandeActies').subscribe(acties => this.geplandeActies = acties));
30
+ this.subscriptions.push(store.select('editable').subscribe(editable => this.editable = editable));
31
+ // listen to changes from svg-viewer-component, saving ritdeel in store isn't cool because of all the gwt in it. This is
32
+ // just to make changes within the angular lifecycle.
33
+ this.subscriptions.push(store.select('selectedRitdeelId').pipe(filter(id => !id)).subscribe(this.deselectRitdeel));
34
+ this.subscriptions.push(combineLatest([
35
+ this.store.select('ritDelen'),
36
+ this.store.select('ongeplandeActies')
37
+ ]).subscribe(() => this.updateOngeplandeActiesList()));
38
+ }
39
+ ngOnDestroy() {
40
+ this.subscriptions.forEach(s => s.unsubscribe());
41
+ }
42
+ isRitdeelZichtbaar(ritdeel) {
43
+ return ritdeel.isZichtbaar();
44
+ }
45
+ toggleRitdeelZichtbaarheid(ritdeel) {
46
+ this.deselectRitdeel();
47
+ this.store.dispatch(RitdelenActions.toggleRitdeelZichtbaar(ritdeel));
48
+ }
49
+ toggleZichtbaarheidAlleRitdelen(checked) {
50
+ this.deselectRitdeel();
51
+ this.store.dispatch(RitdelenActions.setZichtbaarheidAlleRitdelen(checked));
52
+ }
53
+ isRitdeelNieuw(ritdeel) {
54
+ return ritdeel.isNieuw() ? '+' : '';
55
+ }
56
+ getTitle(ritdeel) {
57
+ return ritdeel.getBewegingId();
58
+ }
59
+ getTreinNummer(ritdeel) {
60
+ return ritdeel.getTreinNummer();
61
+ }
62
+ deleteRitdeel(ritdeel) {
63
+ ritdeel.acties.forEach(actie => {
64
+ this.verhuisActieNaarOngepland(actie);
65
+ });
66
+ this.deselectRitdeel();
67
+ this.store.dispatch(RitdelenActions.deleteRitdeel(ritdeel));
68
+ }
69
+ deleteActiesUitRit() {
70
+ this.selectedRitdeel.acties.slice().forEach(actie => {
71
+ this.deleteActieUitRit(actie);
72
+ });
73
+ }
74
+ deleteActieUitRit(actie) {
75
+ const acties = this.selectedRitdeel.acties;
76
+ const idx = acties.indexOf(actie);
77
+ if (idx >= 0) {
78
+ this.verhuisActieNaarOngepland(actie);
79
+ this.store.dispatch(RitdelenActions.deleteRitdeelActie(this.selectedRitdeel, acties[idx]));
80
+ }
81
+ const index = this.nietGeplandeActies.indexOf(actie);
82
+ if (index < 0) {
83
+ this.nietGeplandeActies.push(actie);
84
+ }
85
+ }
86
+ verhuisActieNaarOngepland(actie) {
87
+ const puics = this.geplandeActies.get(actie);
88
+ if (puics && puics.length > 0) {
89
+ this.store.dispatch(MstActions.AddOngeplandeActie(new OngeplandeActie(actie, puics)));
90
+ this.store.dispatch(MstActions.DeleteGeplandeActie(actie, puics));
91
+ }
92
+ }
93
+ voegActiesToeAanRit() {
94
+ const acties = this.selectedRitdeelOngeplandeActies;
95
+ acties.slice().forEach(actie => {
96
+ this.voegActieToeAanRit(actie);
97
+ });
98
+ }
99
+ voegActieToeAanRit(ongeplandeActie) {
100
+ const idx = this.selectedRitdeelOngeplandeActies.indexOf(ongeplandeActie);
101
+ if (idx >= 0) {
102
+ this.store.dispatch(RitdelenActions.addRitdeelActie(this.selectedRitdeel, this.selectedRitdeelOngeplandeActies[idx].actie));
103
+ this.store.dispatch(MstActions.AddGeplandeActie(ongeplandeActie.actie, ongeplandeActie.puics));
104
+ this.store.dispatch(MstActions.DeleteOngeplandeActie(ongeplandeActie));
105
+ }
106
+ }
107
+ updateOngeplandeActiesList() {
108
+ if (this.selectedRitdeel) {
109
+ this.selectedRitdeelOngeplandeActies = [];
110
+ const ritPuics = [];
111
+ const ritdeelTopoElements = ActieHelper.getActieTopoElements(this.selectedRitdeel, this.sbmService);
112
+ const wisselObjecten = JsJavaUtil.listToArray(this.selectedRitdeel.getRoute().getWisselObjectenInDeRoute());
113
+ ritdeelTopoElements.forEach(elem => ritPuics.push(elem.getPuic()));
114
+ const ongeplandeActiesArray = this.ongeplandeActiesMap.values();
115
+ ongeplandeActiesArray.forEach(oa => {
116
+ const acties = this.ritdeelViewModels.flatMap(rd => rd.ritdeel.acties);
117
+ const alreadyAdded = acties.filter(a => a.id === oa.actie.id).length > 0;
118
+ if (!alreadyAdded) {
119
+ let oaMatch;
120
+ if (ActieHelper.isVSTActie(oa.actie)) {
121
+ oaMatch = this.matchedWisselMetKantCodeInVSTActie(oa, wisselObjecten) ? oa : undefined;
122
+ }
123
+ else if (oa.puics.filter(p => ritPuics.includes(p) || this.bevatWisselPuic(ritPuics, p)).length > 0) {
124
+ oaMatch = oa;
125
+ }
126
+ const alreadyAddedAsOngepland = this.selectedRitdeelOngeplandeActies.filter(a => a.actie.id === oa.actie.id).length > 0;
127
+ if (oaMatch && !alreadyAddedAsOngepland) {
128
+ this.selectedRitdeelOngeplandeActies.push(oaMatch);
129
+ }
130
+ }
131
+ });
132
+ }
133
+ }
134
+ matchedWisselMetKantCodeInVSTActie(ongeplandeActie, wissels) {
135
+ const pplg = ongeplandeActie.actie.pplgNaam;
136
+ const wisselKantCodes = ActieHelper.getWisselKantCodes(ongeplandeActie.actie);
137
+ let gevondenWissels = 0;
138
+ let gevondenWisselKantCodes = 0;
139
+ wisselKantCodes.forEach((wisselKantCode) => {
140
+ const gevondenWissel = this.findWisselOpNaamEnPplg(wissels, wisselKantCode.naam, pplg);
141
+ if (gevondenWissel) {
142
+ gevondenWissels++;
143
+ if (this.getKantCode(gevondenWissel.getStand()) === wisselKantCode.kantCode) {
144
+ gevondenWisselKantCodes++;
145
+ }
146
+ }
147
+ });
148
+ return gevondenWissels > 0 && gevondenWissels === gevondenWisselKantCodes;
149
+ }
150
+ findWisselOpNaamEnPplg(wissels, wisselNaam, pplgNaam) {
151
+ return wissels.find(wo => wo.getName() === wisselNaam && wo.getPPLG() === pplgNaam);
152
+ }
153
+ bevatWisselPuic(ritPuics, p) {
154
+ return ritPuics.includes(this.sbmService.getWisselMetStoringskaderPuic(p)?.getPuic());
155
+ }
156
+ selectedRitdeelClass(ritdeel) {
157
+ if (ritdeel.getZichtbaarheidBuitenPaginatie()) {
158
+ if (ritdeel.equals(this.selectedRitdeel)) {
159
+ return 'selected';
160
+ }
161
+ return 'visible-outside-window';
162
+ }
163
+ if (ritdeel.isNietBeschikbaar()) {
164
+ return 'disabled';
165
+ }
166
+ if (ritdeel.equals(this.selectedRitdeel)) {
167
+ return 'selected';
168
+ }
169
+ return '';
170
+ }
171
+ selectRitdeel(event, ritdeel) {
172
+ if (event?.ctrlKey) {
173
+ this.focusEmitter.emit(ritdeel);
174
+ }
175
+ else {
176
+ if (ritdeel?.equals(this.selectedRitdeel)) {
177
+ this.deselectRitdeel();
178
+ return;
179
+ }
180
+ this.selectedRitdeel = ritdeel;
181
+ this.disableActieKnoppenVanRitdeel = !this.selectedRitdeel.isZichtbaar();
182
+ if (ritdeel.acties) {
183
+ this.selectedRitdeelActies = ritdeel.acties;
184
+ this.updateOngeplandeActiesList();
185
+ }
186
+ else {
187
+ this.selectedRitdeelActies = [];
188
+ this.selectedRitdeelOngeplandeActies = [];
189
+ }
190
+ }
191
+ }
192
+ actieOmschrijvingTekst(actie) {
193
+ const prefix = this.bepaalPrefixVoorActieOmschrijving(actie);
194
+ if (ActieHelper.isVSTActie(actie)) {
195
+ return this.maakVstActieOmschrijving(actie, prefix);
196
+ }
197
+ return prefix + actie.ritActieTypeOmschrijving;
198
+ }
199
+ maakVstActieOmschrijving(actie, prefix) {
200
+ return `${prefix}${ActieHelper.getVSTActieOmschrijving(actie)}`;
201
+ }
202
+ bepaalPrefixVoorActieOmschrijving(actie) {
203
+ const prefix = '';
204
+ if (this.selectedRitdeel.acties.includes(actie)) {
205
+ // Afwijkende naam bij niet gevisualiseerde actie in rit
206
+ const puics = this.geplandeActies.get(actie);
207
+ return puics.length > 0 ? prefix : this.NG_ACTIE_PREFIX;
208
+ }
209
+ return prefix;
210
+ }
211
+ actieVanKmTekst(actie) {
212
+ if (ActieHelper.isWisselSlijpenActie(actie)) {
213
+ return actie.wisselNaam;
214
+ }
215
+ return actie.vanKilometerlint ? actie.vanKilometerlint + ' ' + actie.vanKilometrering : '-';
216
+ }
217
+ actieTotKmTekst(actie) {
218
+ return actie.totKilometerlint ? actie.totKilometerlint + ' ' + actie.totKilometrering : '-';
219
+ }
220
+ deselectRitdeel() {
221
+ this.disableActieKnoppenVanRitdeel = false;
222
+ this.selectedRitdeel = undefined;
223
+ this.selectedRitdeelActies = [];
224
+ this.selectedRitdeelOngeplandeActies = [];
225
+ }
226
+ getPplgString(ritdeel) {
227
+ return ritdeel.getPplgString();
228
+ }
229
+ getKantCode(stand) {
230
+ if (stand === window['domein'].Stand.LINKS) {
231
+ return 'L';
232
+ }
233
+ return 'R';
234
+ }
235
+ planAlleRitActies() {
236
+ this.keurAlleActiesGoed.emit();
237
+ this.deselectRitdeel();
238
+ }
239
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: RitdelenLijstComponent, deps: [{ token: i1.Store }, { token: i2.SignaleringsBeeldManagerService }], target: i0.ɵɵFactoryTarget.Component }); }
240
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.7", type: RitdelenLijstComponent, selector: "ritdelen-lijst", inputs: { nietGeplandeActies: "nietGeplandeActies" }, outputs: { focusEmitter: "focusEmitter", keurAlleActiesGoed: "keurAlleActiesGoed" }, ngImport: i0, template: "<div id=\"ritdelen-lijst\">\n <div class=\"sidebar-header\">\n <h3 [attr.data-test-id]=\"'title-rit-details'\">Ritdetails</h3>\n </div>\n <div class=\"panes-container\">\n <div class=\"top-pane tableFixHead\" id=\"top-pane\">\n <table class=\"table\" aria-hidden=\"true\" [attr.data-test-id]=\"'table-rit-details'\">\n <thead>\n <tr>\n <th scope=\"col\">\n <input #input\n type=\"checkbox\"\n checked\n class=\"checkbox col-visibility\"\n (change)=\"toggleZichtbaarheidAlleRitdelen(input.checked)\"\n id=\"ritdetails-selecteerAlles\"\n title=\"Selecteer alles\"\n [attr.data-test-id]=\"'checkbox-alle-bewegingen'\">\n </th>\n <th scope=\"col\"></th>\n <th scope=\"col\">Van</th>\n <th scope=\"col\">Naar</th>\n <th scope=\"col\">DW</th>\n <th scope=\"col\">PPLG(s)</th>\n <th scope=\"col\">Treinnr.</th>\n <th scope=\"col\"></th>\n </tr>\n </thead>\n\n <tr *ngFor=\"let ritdeelViewModel of ritdeelViewModels; let i = index\"\n class=\"{{ selectedRitdeelClass(ritdeelViewModel.ritdeel) }}\" id=\"ritdetails-r{{i}}\">\n <td>\n <input id=\"ritdetails-r{{i}}-zichtbaar\"\n [attr.data-test-id]=\"'checkbox-r'+i\"\n type=\"checkbox\"\n class=\"checkbox col-visibility\"\n [checked]=\"ritdeelViewModel.isZichtbaar\"\n [title]=\"ritdeelViewModel.title\"\n (change)=\"toggleRitdeelZichtbaarheid(ritdeelViewModel.ritdeel)\"\n [hidden]=\"ritdeelViewModel.isNietBeschikbaar\"/>\n </td>\n <td id=\"ritdetails-r{{i}}-gewijzigd\" (click)=\"selectRitdeel($event, ritdeelViewModel.ritdeel)\">{{ritdeelViewModel.isNieuw}}</td>\n <td id=\"ritdetails-r{{i}}-vanSpoor\" (click)=\"selectRitdeel($event, ritdeelViewModel.ritdeel)\">{{ritdeelViewModel.vanPrlSpoor}}</td>\n <td id=\"ritdetails-r{{i}}-naarSpoor\" (click)=\"selectRitdeel($event, ritdeelViewModel.ritdeel)\">{{ritdeelViewModel.naarPrlSpoor}}</td>\n <td id=\"ritdetails-r{{i}}-dwangNummer\" (click)=\"selectRitdeel($event, ritdeelViewModel.ritdeel)\">{{ritdeelViewModel.dwangNummer}}</td>\n <td id=\"ritdetails-r{{i}}-pplgs\" (click)=\"selectRitdeel($event, ritdeelViewModel.ritdeel)\">{{ritdeelViewModel.pplgString}}</td>\n <td id=\"ritdetails-r{{i}}-treinNummer\" (click)=\"selectRitdeel($event, ritdeelViewModel.ritdeel)\">{{ritdeelViewModel.treinNummer}}</td>\n <td style=\"text-align:right\">\n <button *ngIf=\"editable\"\n id=\"ritdetails-r{{i}}-del\"\n type=\"button\"\n class=\"loxia-btn loxia-btn-danger btn-sm\"\n (click)=\"deleteRitdeel(ritdeelViewModel.ritdeel)\">X\n </button>\n </td>\n </tr>\n\n </table>\n </div>\n <div class=\"actie-pane\">\n <div *ngIf=\"selectedRitdeel && (selectedRitdeelActies.length > 0 || selectedRitdeelOngeplandeActies.length > 0) \"\n id=\"actie-pane\">\n <h4>Geplande acties</h4>\n <table aria-hidden=\"true\">\n <tr>\n <th scope=\"col\">Actie</th>\n <th scope=\"col\">Van</th>\n <th scope=\"col\">Tot</th>\n <th scope=\"col\">\n <button *ngIf=\"editable\"\n [hidden]=\"selectedRitdeelActies.length===0\"\n id=\"bulkSetOngeplandButton\"\n [attr.data-test-id]=\"'unplan-all-actions'\"\n type=\"button\"\n class=\"loxia-btn loxia-btn-danger btn-sm\"\n (click)=\"deleteActiesUitRit()\"\n [disabled]=\"disableActieKnoppenVanRitdeel\">X\n </button>\n </th>\n </tr>\n\n <tr *ngFor=\"let actie of selectedRitdeelActies; let i = index\" id=\"ritdetails-a{{i}}\">\n <td id=\"ritdetails-a{{i}}-omschrijving\" class=\"nowrap\">{{ actieOmschrijvingTekst(actie) }}</td>\n <td id=\"ritdetails-a{{i}}-vanKmLint\">{{ actieVanKmTekst(actie)}}</td>\n <td id=\"ritdetails-a{{i}}-totKmLint\">{{ actieTotKmTekst(actie)}}</td>\n <td style=\"text-align:right\">\n <button *ngIf=\"editable\"\n id=\"ritdetails-a{{i}}-del\"\n type=\"button\"\n class=\"loxia-btn loxia-btn-danger btn-sm\"\n (click)=\"deleteActieUitRit(actie)\"\n [disabled]=\"disableActieKnoppenVanRitdeel\">X\n </button>\n </td>\n </tr>\n </table>\n <h4>Ongeplande acties</h4>\n <table aria-hidden=\"true\">\n <tr>\n <th scope=\"col\">Actie</th>\n <th scope=\"col\">Van</th>\n <th scope=\"col\">Tot</th>\n <th scope=\"col\">\n <button *ngIf=\"editable\"\n [hidden]=\"selectedRitdeelOngeplandeActies.length===0\"\n id=\"bulkSetGeplandButton\"\n [attr.data-test-id]=\"'plan-all-actions'\"\n type=\"button\"\n class=\"loxia-btn loxia-btn-success loxia-btn-sm\"\n (click)=\"voegActiesToeAanRit()\"\n [disabled]=\"disableActieKnoppenVanRitdeel\">^\n </button>\n </th>\n </tr>\n\n <tr *ngFor=\"let ongeplandeActie of selectedRitdeelOngeplandeActies; let i = index\"\n id=\"ritdetails-oa{{i}}\">\n <td id=\"ritdetails-oa{{i}}-omschrijving\" class=\"nowrap\">{{actieOmschrijvingTekst(ongeplandeActie.actie) }}</td>\n <td id=\"ritdetails-oa{{i}}-vanKmLint\">{{ actieVanKmTekst(ongeplandeActie.actie)}}</td>\n <td id=\"ritdetails-oa{{i}}-totKmLint\">{{ actieTotKmTekst(ongeplandeActie.actie)}}</td>\n <td style=\"text-align:right\">\n <button *ngIf=\"editable\"\n id=\"ritdetails-oa{{i}}-del\"\n type=\"button\"\n class=\"loxia-btn loxia-btn-success loxia-btn-sm\"\n (click)=\"voegActieToeAanRit(ongeplandeActie)\"\n [disabled]=\"disableActieKnoppenVanRitdeel\">^\n </button>\n </td>\n </tr>\n </table>\n </div>\n </div>\n <div class=\"knop-pane\">\n <button type=\"button\"\n class=\"loxia-btn loxia-btn-primary loxia-btn-sm\"\n [attr.data-test-id]=\"'plan-all-actions-for-file'\"\n [innerText]=\"'Plan acties hele rit'\"\n (click)=\"planAlleRitActies()\">\n </button>\n </div>\n </div>\n</div>\n", styles: [".panes-container{display:inline;height:100%;border:1px solid black}table{width:100%}th{padding:5px;z-index:1000}td{padding:4px}tr:nth-child(2n){background:#f0f0f0}tr:nth-child(odd){background:#fff}.top-pane{height:45vh;overflow:auto}.actie-pane{height:35vh;overflow:auto}.knop-pane{height:5vh;justify-content:center;display:flex;align-items:center}.panes-container,.panes-separator,.top-pane,.actie-pane{margin:0;padding:0;width:100%}.selected{background:#ffff80!important}.disabled{background:gray!important}.visible-outside-window{background:#87cefa!important}.table-scroll-header-fix tbody{display:block;height:40vh;overflow:auto}.tableFixHead{overflow-y:auto}.tableFixHead thead th{position:sticky;top:0;background-color:#fff}.table{margin-bottom:0}.table td,.table th{border-top:none;border-bottom:none;padding-left:.75em}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.Default }); }
241
+ }
242
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: RitdelenLijstComponent, decorators: [{
243
+ type: Component,
244
+ args: [{ selector: 'ritdelen-lijst', changeDetection: ChangeDetectionStrategy.Default, template: "<div id=\"ritdelen-lijst\">\n <div class=\"sidebar-header\">\n <h3 [attr.data-test-id]=\"'title-rit-details'\">Ritdetails</h3>\n </div>\n <div class=\"panes-container\">\n <div class=\"top-pane tableFixHead\" id=\"top-pane\">\n <table class=\"table\" aria-hidden=\"true\" [attr.data-test-id]=\"'table-rit-details'\">\n <thead>\n <tr>\n <th scope=\"col\">\n <input #input\n type=\"checkbox\"\n checked\n class=\"checkbox col-visibility\"\n (change)=\"toggleZichtbaarheidAlleRitdelen(input.checked)\"\n id=\"ritdetails-selecteerAlles\"\n title=\"Selecteer alles\"\n [attr.data-test-id]=\"'checkbox-alle-bewegingen'\">\n </th>\n <th scope=\"col\"></th>\n <th scope=\"col\">Van</th>\n <th scope=\"col\">Naar</th>\n <th scope=\"col\">DW</th>\n <th scope=\"col\">PPLG(s)</th>\n <th scope=\"col\">Treinnr.</th>\n <th scope=\"col\"></th>\n </tr>\n </thead>\n\n <tr *ngFor=\"let ritdeelViewModel of ritdeelViewModels; let i = index\"\n class=\"{{ selectedRitdeelClass(ritdeelViewModel.ritdeel) }}\" id=\"ritdetails-r{{i}}\">\n <td>\n <input id=\"ritdetails-r{{i}}-zichtbaar\"\n [attr.data-test-id]=\"'checkbox-r'+i\"\n type=\"checkbox\"\n class=\"checkbox col-visibility\"\n [checked]=\"ritdeelViewModel.isZichtbaar\"\n [title]=\"ritdeelViewModel.title\"\n (change)=\"toggleRitdeelZichtbaarheid(ritdeelViewModel.ritdeel)\"\n [hidden]=\"ritdeelViewModel.isNietBeschikbaar\"/>\n </td>\n <td id=\"ritdetails-r{{i}}-gewijzigd\" (click)=\"selectRitdeel($event, ritdeelViewModel.ritdeel)\">{{ritdeelViewModel.isNieuw}}</td>\n <td id=\"ritdetails-r{{i}}-vanSpoor\" (click)=\"selectRitdeel($event, ritdeelViewModel.ritdeel)\">{{ritdeelViewModel.vanPrlSpoor}}</td>\n <td id=\"ritdetails-r{{i}}-naarSpoor\" (click)=\"selectRitdeel($event, ritdeelViewModel.ritdeel)\">{{ritdeelViewModel.naarPrlSpoor}}</td>\n <td id=\"ritdetails-r{{i}}-dwangNummer\" (click)=\"selectRitdeel($event, ritdeelViewModel.ritdeel)\">{{ritdeelViewModel.dwangNummer}}</td>\n <td id=\"ritdetails-r{{i}}-pplgs\" (click)=\"selectRitdeel($event, ritdeelViewModel.ritdeel)\">{{ritdeelViewModel.pplgString}}</td>\n <td id=\"ritdetails-r{{i}}-treinNummer\" (click)=\"selectRitdeel($event, ritdeelViewModel.ritdeel)\">{{ritdeelViewModel.treinNummer}}</td>\n <td style=\"text-align:right\">\n <button *ngIf=\"editable\"\n id=\"ritdetails-r{{i}}-del\"\n type=\"button\"\n class=\"loxia-btn loxia-btn-danger btn-sm\"\n (click)=\"deleteRitdeel(ritdeelViewModel.ritdeel)\">X\n </button>\n </td>\n </tr>\n\n </table>\n </div>\n <div class=\"actie-pane\">\n <div *ngIf=\"selectedRitdeel && (selectedRitdeelActies.length > 0 || selectedRitdeelOngeplandeActies.length > 0) \"\n id=\"actie-pane\">\n <h4>Geplande acties</h4>\n <table aria-hidden=\"true\">\n <tr>\n <th scope=\"col\">Actie</th>\n <th scope=\"col\">Van</th>\n <th scope=\"col\">Tot</th>\n <th scope=\"col\">\n <button *ngIf=\"editable\"\n [hidden]=\"selectedRitdeelActies.length===0\"\n id=\"bulkSetOngeplandButton\"\n [attr.data-test-id]=\"'unplan-all-actions'\"\n type=\"button\"\n class=\"loxia-btn loxia-btn-danger btn-sm\"\n (click)=\"deleteActiesUitRit()\"\n [disabled]=\"disableActieKnoppenVanRitdeel\">X\n </button>\n </th>\n </tr>\n\n <tr *ngFor=\"let actie of selectedRitdeelActies; let i = index\" id=\"ritdetails-a{{i}}\">\n <td id=\"ritdetails-a{{i}}-omschrijving\" class=\"nowrap\">{{ actieOmschrijvingTekst(actie) }}</td>\n <td id=\"ritdetails-a{{i}}-vanKmLint\">{{ actieVanKmTekst(actie)}}</td>\n <td id=\"ritdetails-a{{i}}-totKmLint\">{{ actieTotKmTekst(actie)}}</td>\n <td style=\"text-align:right\">\n <button *ngIf=\"editable\"\n id=\"ritdetails-a{{i}}-del\"\n type=\"button\"\n class=\"loxia-btn loxia-btn-danger btn-sm\"\n (click)=\"deleteActieUitRit(actie)\"\n [disabled]=\"disableActieKnoppenVanRitdeel\">X\n </button>\n </td>\n </tr>\n </table>\n <h4>Ongeplande acties</h4>\n <table aria-hidden=\"true\">\n <tr>\n <th scope=\"col\">Actie</th>\n <th scope=\"col\">Van</th>\n <th scope=\"col\">Tot</th>\n <th scope=\"col\">\n <button *ngIf=\"editable\"\n [hidden]=\"selectedRitdeelOngeplandeActies.length===0\"\n id=\"bulkSetGeplandButton\"\n [attr.data-test-id]=\"'plan-all-actions'\"\n type=\"button\"\n class=\"loxia-btn loxia-btn-success loxia-btn-sm\"\n (click)=\"voegActiesToeAanRit()\"\n [disabled]=\"disableActieKnoppenVanRitdeel\">^\n </button>\n </th>\n </tr>\n\n <tr *ngFor=\"let ongeplandeActie of selectedRitdeelOngeplandeActies; let i = index\"\n id=\"ritdetails-oa{{i}}\">\n <td id=\"ritdetails-oa{{i}}-omschrijving\" class=\"nowrap\">{{actieOmschrijvingTekst(ongeplandeActie.actie) }}</td>\n <td id=\"ritdetails-oa{{i}}-vanKmLint\">{{ actieVanKmTekst(ongeplandeActie.actie)}}</td>\n <td id=\"ritdetails-oa{{i}}-totKmLint\">{{ actieTotKmTekst(ongeplandeActie.actie)}}</td>\n <td style=\"text-align:right\">\n <button *ngIf=\"editable\"\n id=\"ritdetails-oa{{i}}-del\"\n type=\"button\"\n class=\"loxia-btn loxia-btn-success loxia-btn-sm\"\n (click)=\"voegActieToeAanRit(ongeplandeActie)\"\n [disabled]=\"disableActieKnoppenVanRitdeel\">^\n </button>\n </td>\n </tr>\n </table>\n </div>\n </div>\n <div class=\"knop-pane\">\n <button type=\"button\"\n class=\"loxia-btn loxia-btn-primary loxia-btn-sm\"\n [attr.data-test-id]=\"'plan-all-actions-for-file'\"\n [innerText]=\"'Plan acties hele rit'\"\n (click)=\"planAlleRitActies()\">\n </button>\n </div>\n </div>\n</div>\n", styles: [".panes-container{display:inline;height:100%;border:1px solid black}table{width:100%}th{padding:5px;z-index:1000}td{padding:4px}tr:nth-child(2n){background:#f0f0f0}tr:nth-child(odd){background:#fff}.top-pane{height:45vh;overflow:auto}.actie-pane{height:35vh;overflow:auto}.knop-pane{height:5vh;justify-content:center;display:flex;align-items:center}.panes-container,.panes-separator,.top-pane,.actie-pane{margin:0;padding:0;width:100%}.selected{background:#ffff80!important}.disabled{background:gray!important}.visible-outside-window{background:#87cefa!important}.table-scroll-header-fix tbody{display:block;height:40vh;overflow:auto}.tableFixHead{overflow-y:auto}.tableFixHead thead th{position:sticky;top:0;background-color:#fff}.table{margin-bottom:0}.table td,.table th{border-top:none;border-bottom:none;padding-left:.75em}\n"] }]
245
+ }], ctorParameters: () => [{ type: i1.Store }, { type: i2.SignaleringsBeeldManagerService }], propDecorators: { nietGeplandeActies: [{
246
+ type: Input
247
+ }], focusEmitter: [{
248
+ type: Output
249
+ }], keurAlleActiesGoed: [{
250
+ type: Output
251
+ }] } });
252
+ class RitdeelViewModel {
253
+ constructor(ritdeel, selectedRitdeelClass, isZichtbaar, title, isNietBeschikbaar, isNieuw, vanPrlSpoor, naarPrlSpoor, dwangNummer, pplgString, treinNummer) {
254
+ this.ritdeel = ritdeel;
255
+ this.selectedRitdeelClass = selectedRitdeelClass;
256
+ this.isZichtbaar = isZichtbaar;
257
+ this.title = title;
258
+ this.isNietBeschikbaar = isNietBeschikbaar;
259
+ this.isNieuw = isNieuw;
260
+ this.vanPrlSpoor = vanPrlSpoor;
261
+ this.naarPrlSpoor = naarPrlSpoor;
262
+ this.dwangNummer = dwangNummer;
263
+ this.pplgString = pplgString;
264
+ this.treinNummer = treinNummer;
265
+ }
266
+ }
267
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ritdelen-lijst.component.js","sourceRoot":"","sources":["../../../../../../projects/mst-viewer/src/lib/components/ritdelen-lijst/ritdelen-lijst.component.ts","../../../../../../projects/mst-viewer/src/lib/components/ritdelen-lijst/ritdelen-lijst.component.html"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectionStrategy, Component, EventEmitter, Input, OnDestroy, Output} from '@angular/core';\nimport {domein, JsJavaUtil} from '@loxia/rijwegen';\nimport {Store} from '@ngrx/store';\nimport {combineLatest, Subscription} from 'rxjs';\nimport {filter} from 'rxjs/operators';\nimport {OngeplandeActie} from '../../model/ongeplande-actie';\nimport {Ritdeel} from '../../model/ritdeel';\nimport {Actie} from '../../optimo';\nimport {SignaleringsBeeldManagerService} from '../../services/signalerings-beeld-manager.service';\nimport * as MstActions from '../../state/actions/actions';\nimport * as RitdelenActions from '../../state/actions/ritdelen.actions';\nimport {MstEditorState} from '../../state/mst-editor-state';\nimport {ActieHelper} from '../../util/actie-helper';\nimport {ArrayMultimap} from '../../util/multi-map';\n\n@Component({\n    selector: 'ritdelen-lijst',\n    templateUrl: './ritdelen-lijst.component.html',\n    styleUrls: ['./ritdelen-lijst.component.scss'],\n    changeDetection: ChangeDetectionStrategy.Default\n})\nexport class RitdelenLijstComponent implements OnDestroy {\n    @Input() nietGeplandeActies: Actie[];\n\n    @Output() focusEmitter = new EventEmitter<Ritdeel>();\n    @Output() keurAlleActiesGoed = new EventEmitter();\n\n    ritdeelViewModels: RitdeelViewModel[];\n    selectedRitdeel: Ritdeel;\n    selectedRitdeelActies: Actie[] = [];\n    selectedRitdeelOngeplandeActies: OngeplandeActie[] = [];\n    disableActieKnoppenVanRitdeel: boolean;\n    editable: boolean;\n\n    private ongeplandeActiesMap: ArrayMultimap<string, OngeplandeActie>;\n    private geplandeActies: ArrayMultimap<Actie, string>;\n    private readonly NG_ACTIE_PREFIX = '* ';\n    private readonly subscriptions: Subscription[] = [];\n\n    constructor(private readonly store: Store<MstEditorState>, private readonly sbmService: SignaleringsBeeldManagerService) {\n        this.subscriptions.push(store.select('ritDelen').subscribe((ritdelen) => {\n            this.ritdeelViewModels = ritdelen?.map(ritdeel => {\n                return new RitdeelViewModel(\n                    ritdeel,\n                    this.selectedRitdeelClass(ritdeel),\n                    this.isRitdeelZichtbaar(ritdeel),\n                    this.getTitle(ritdeel),\n                    ritdeel.isNietBeschikbaar(),\n                    this.isRitdeelNieuw(ritdeel),\n                    ritdeel.getVanPrlSpoor(),\n                    ritdeel.getNaarPrlSpoorText(),\n                    ritdeel.getDwangNummer(),\n                    ritdeel.getPplgString(),\n                    this.getTreinNummer(ritdeel));\n            })\n        }));\n        this.subscriptions.push(store.select('ongeplandeActies').subscribe(acties => this.ongeplandeActiesMap = acties));\n        this.subscriptions.push(store.select('geplandeActies').subscribe(acties => this.geplandeActies = acties));\n        this.subscriptions.push(store.select('editable').subscribe(editable => this.editable = editable));\n\n        // listen to changes from svg-viewer-component, saving ritdeel in store isn't cool because of all the gwt in it. This is\n        // just to make changes within the angular lifecycle.\n        this.subscriptions.push(store.select('selectedRitdeelId').pipe(\n            filter(id => !id)).subscribe(this.deselectRitdeel\n        ));\n\n        this.subscriptions.push(\n            combineLatest([\n            this.store.select('ritDelen'),\n            this.store.select('ongeplandeActies')]\n        ).subscribe(() => this.updateOngeplandeActiesList()));\n    }\n\n    ngOnDestroy(): void {\n        this.subscriptions.forEach(s => s.unsubscribe());\n    }\n\n    isRitdeelZichtbaar(ritdeel: Ritdeel): boolean {\n        return ritdeel.isZichtbaar();\n    }\n\n    toggleRitdeelZichtbaarheid(ritdeel: Ritdeel): void {\n        this.deselectRitdeel();\n        this.store.dispatch(RitdelenActions.toggleRitdeelZichtbaar(ritdeel));\n    }\n\n    toggleZichtbaarheidAlleRitdelen(checked: boolean): void {\n        this.deselectRitdeel();\n        this.store.dispatch(RitdelenActions.setZichtbaarheidAlleRitdelen(checked));\n    }\n\n    isRitdeelNieuw(ritdeel: Ritdeel): string {\n        return ritdeel.isNieuw() ? '+' : '';\n    }\n\n    getTitle(ritdeel: Ritdeel): string {\n        return ritdeel.getBewegingId();\n    }\n\n    getTreinNummer(ritdeel: Ritdeel): string {\n        return ritdeel.getTreinNummer();\n    }\n\n    deleteRitdeel(ritdeel: Ritdeel): void {\n        ritdeel.acties.forEach(actie => {\n            this.verhuisActieNaarOngepland(actie);\n        });\n        this.deselectRitdeel();\n        this.store.dispatch(RitdelenActions.deleteRitdeel(ritdeel));\n    }\n\n    deleteActiesUitRit(): void {\n        this.selectedRitdeel.acties.slice().forEach(actie => {\n            this.deleteActieUitRit(actie);\n        });\n    }\n\n    deleteActieUitRit(actie): void {\n        const acties = this.selectedRitdeel.acties;\n        const idx = acties.indexOf(actie);\n        if (idx >= 0) {\n            this.verhuisActieNaarOngepland(actie);\n            this.store.dispatch(RitdelenActions.deleteRitdeelActie(this.selectedRitdeel, acties[idx]));\n        }\n        const index = this.nietGeplandeActies.indexOf(actie);\n        if (index < 0) {\n            this.nietGeplandeActies.push(actie);\n        }\n    }\n\n    private verhuisActieNaarOngepland(actie): void {\n        const puics = this.geplandeActies.get(actie);\n\n        if (puics && puics.length > 0) {\n            this.store.dispatch(MstActions.AddOngeplandeActie(new OngeplandeActie(actie, puics)));\n            this.store.dispatch(MstActions.DeleteGeplandeActie(actie, puics));\n        }\n    }\n\n    voegActiesToeAanRit(): void {\n        const acties = this.selectedRitdeelOngeplandeActies;\n        acties.slice().forEach(actie => {\n            this.voegActieToeAanRit(actie);\n        });\n    }\n\n    voegActieToeAanRit(ongeplandeActie: OngeplandeActie): void {\n        const idx = this.selectedRitdeelOngeplandeActies.indexOf(ongeplandeActie);\n        if (idx >= 0) {\n            this.store.dispatch(RitdelenActions.addRitdeelActie(this.selectedRitdeel, this.selectedRitdeelOngeplandeActies[idx].actie));\n            this.store.dispatch(MstActions.AddGeplandeActie(ongeplandeActie.actie, ongeplandeActie.puics));\n            this.store.dispatch(MstActions.DeleteOngeplandeActie(ongeplandeActie));\n        }\n    }\n\n    updateOngeplandeActiesList(): void {\n        if (this.selectedRitdeel) {\n            this.selectedRitdeelOngeplandeActies = [];\n            const ritPuics: string[] = [];\n            const ritdeelTopoElements = ActieHelper.getActieTopoElements(this.selectedRitdeel, this.sbmService);\n            const wisselObjecten: domein.Wissel[] = JsJavaUtil.listToArray(this.selectedRitdeel.getRoute().getWisselObjectenInDeRoute());\n\n            ritdeelTopoElements.forEach(elem => ritPuics.push(elem.getPuic()));\n            const ongeplandeActiesArray = this.ongeplandeActiesMap.values();\n            ongeplandeActiesArray.forEach(oa => {\n                const acties = this.ritdeelViewModels.flatMap(rd => rd.ritdeel.acties);\n                const alreadyAdded = acties.filter(a => a.id === oa.actie.id).length > 0;\n                if (!alreadyAdded) {\n                    let oaMatch;\n                    if (ActieHelper.isVSTActie(oa.actie)) {\n                        oaMatch = this.matchedWisselMetKantCodeInVSTActie(oa, wisselObjecten) ? oa : undefined;\n                    } else if (oa.puics.filter(p => ritPuics.includes(p) || this.bevatWisselPuic(ritPuics, p)).length > 0) {\n                        oaMatch = oa;\n                    }\n\n                    const alreadyAddedAsOngepland = this.selectedRitdeelOngeplandeActies.filter(a => a.actie.id === oa.actie.id).length > 0;\n                    if (oaMatch && !alreadyAddedAsOngepland) {\n                        this.selectedRitdeelOngeplandeActies.push(oaMatch);\n                    }\n                }\n            });\n        }\n    }\n\n    matchedWisselMetKantCodeInVSTActie(ongeplandeActie: OngeplandeActie, wissels: domein.Wissel[]): boolean {\n        const pplg = ongeplandeActie.actie.pplgNaam;\n        const wisselKantCodes = ActieHelper.getWisselKantCodes(ongeplandeActie.actie);\n\n        let gevondenWissels = 0;\n        let gevondenWisselKantCodes = 0;\n\n        wisselKantCodes.forEach((wisselKantCode) => {\n            const gevondenWissel = this.findWisselOpNaamEnPplg(wissels, wisselKantCode.naam, pplg);\n\n            if (gevondenWissel) {\n                gevondenWissels++;\n                if (this.getKantCode(gevondenWissel.getStand()) === wisselKantCode.kantCode) {\n                    gevondenWisselKantCodes++;\n                }\n            }\n        });\n\n        return gevondenWissels > 0 && gevondenWissels === gevondenWisselKantCodes;\n    }\n\n    private findWisselOpNaamEnPplg(wissels: domein.Wissel[], wisselNaam: string, pplgNaam: string): domein.Wissel {\n        return wissels.find(wo => wo.getName() === wisselNaam && wo.getPPLG() === pplgNaam);\n    }\n\n    private bevatWisselPuic(ritPuics: string[], p): boolean {\n        return ritPuics.includes(this.sbmService.getWisselMetStoringskaderPuic(p)?.getPuic());\n    }\n\n    selectedRitdeelClass(ritdeel: Ritdeel): string {\n        if (ritdeel.getZichtbaarheidBuitenPaginatie()) {\n            if (ritdeel.equals(this.selectedRitdeel)) {\n                return 'selected';\n            }\n            return 'visible-outside-window';\n        }\n        if (ritdeel.isNietBeschikbaar()) {\n            return 'disabled';\n        }\n        if (ritdeel.equals(this.selectedRitdeel)) {\n            return 'selected';\n        }\n        return '';\n    }\n\n    selectRitdeel(event: MouseEvent, ritdeel: Ritdeel): void {\n        if (event?.ctrlKey) {\n            this.focusEmitter.emit(ritdeel);\n        } else {\n            if (ritdeel?.equals(this.selectedRitdeel)) {\n                this.deselectRitdeel();\n                return;\n            }\n\n            this.selectedRitdeel = ritdeel;\n            this.disableActieKnoppenVanRitdeel = !this.selectedRitdeel.isZichtbaar();\n\n            if (ritdeel.acties) {\n                this.selectedRitdeelActies = ritdeel.acties;\n                this.updateOngeplandeActiesList();\n            } else {\n                this.selectedRitdeelActies = [];\n                this.selectedRitdeelOngeplandeActies = [];\n            }\n        }\n    }\n\n    actieOmschrijvingTekst(actie: Actie): string {\n        const prefix = this.bepaalPrefixVoorActieOmschrijving(actie);\n        if (ActieHelper.isVSTActie(actie)) {\n            return this.maakVstActieOmschrijving(actie, prefix);\n        }\n        return prefix + actie.ritActieTypeOmschrijving;\n    }\n\n    private maakVstActieOmschrijving(actie: Actie, prefix: string): string {\n        return `${ prefix }${ ActieHelper.getVSTActieOmschrijving(actie) }`;\n    }\n\n    bepaalPrefixVoorActieOmschrijving(actie: Actie): string {\n        const prefix = '';\n        if (this.selectedRitdeel.acties.includes(actie)) {\n            // Afwijkende naam bij niet gevisualiseerde actie in rit\n            const puics = this.geplandeActies.get(actie);\n            return puics.length > 0 ? prefix : this.NG_ACTIE_PREFIX;\n        }\n        return prefix;\n    }\n\n    actieVanKmTekst(actie: Actie): string {\n        if (ActieHelper.isWisselSlijpenActie(actie)) {\n            return actie.wisselNaam;\n        }\n        return actie.vanKilometerlint ? actie.vanKilometerlint + ' ' + actie.vanKilometrering : '-';\n    }\n\n    actieTotKmTekst(actie: Actie): string {\n        return actie.totKilometerlint ? actie.totKilometerlint + ' ' + actie.totKilometrering : '-';\n    }\n\n    deselectRitdeel(): void {\n        this.disableActieKnoppenVanRitdeel = false;\n        this.selectedRitdeel = undefined;\n        this.selectedRitdeelActies = [];\n        this.selectedRitdeelOngeplandeActies = [];\n    }\n\n    getPplgString(ritdeel: Ritdeel): string {\n        return ritdeel.getPplgString();\n    }\n\n    private getKantCode(stand: domein.Stand): string {\n        if (stand === window['domein'].Stand.LINKS) {\n            return 'L';\n        }\n        return 'R';\n    }\n\n    planAlleRitActies(): void {\n        this.keurAlleActiesGoed.emit();\n        this.deselectRitdeel();\n    }\n}\n\nclass RitdeelViewModel {\n    constructor(\n        readonly ritdeel: Ritdeel,\n        readonly selectedRitdeelClass: string,\n        readonly isZichtbaar: boolean,\n        readonly title: string,\n        readonly isNietBeschikbaar: boolean,\n        readonly isNieuw: string,\n        readonly vanPrlSpoor: string,\n        readonly naarPrlSpoor: string,\n        readonly dwangNummer: number,\n        readonly pplgString: string,\n        readonly treinNummer: string\n    ) {\n    }\n}\n","<div id=\"ritdelen-lijst\">\n    <div class=\"sidebar-header\">\n        <h3 [attr.data-test-id]=\"'title-rit-details'\">Ritdetails</h3>\n    </div>\n    <div class=\"panes-container\">\n        <div class=\"top-pane tableFixHead\" id=\"top-pane\">\n            <table class=\"table\" aria-hidden=\"true\" [attr.data-test-id]=\"'table-rit-details'\">\n                <thead>\n                <tr>\n                    <th scope=\"col\">\n                        <input #input\n                               type=\"checkbox\"\n                               checked\n                               class=\"checkbox col-visibility\"\n                               (change)=\"toggleZichtbaarheidAlleRitdelen(input.checked)\"\n                               id=\"ritdetails-selecteerAlles\"\n                               title=\"Selecteer alles\"\n                               [attr.data-test-id]=\"'checkbox-alle-bewegingen'\">\n                    </th>\n                    <th scope=\"col\"></th>\n                    <th scope=\"col\">Van</th>\n                    <th scope=\"col\">Naar</th>\n                    <th scope=\"col\">DW</th>\n                    <th scope=\"col\">PPLG(s)</th>\n                    <th scope=\"col\">Treinnr.</th>\n                    <th scope=\"col\"></th>\n                </tr>\n                </thead>\n\n                <tr *ngFor=\"let ritdeelViewModel of ritdeelViewModels; let i = index\"\n                    class=\"{{ selectedRitdeelClass(ritdeelViewModel.ritdeel) }}\" id=\"ritdetails-r{{i}}\">\n                    <td>\n                        <input id=\"ritdetails-r{{i}}-zichtbaar\"\n                               [attr.data-test-id]=\"'checkbox-r'+i\"\n                               type=\"checkbox\"\n                               class=\"checkbox col-visibility\"\n                               [checked]=\"ritdeelViewModel.isZichtbaar\"\n                               [title]=\"ritdeelViewModel.title\"\n                               (change)=\"toggleRitdeelZichtbaarheid(ritdeelViewModel.ritdeel)\"\n                               [hidden]=\"ritdeelViewModel.isNietBeschikbaar\"/>\n                    </td>\n                    <td id=\"ritdetails-r{{i}}-gewijzigd\" (click)=\"selectRitdeel($event, ritdeelViewModel.ritdeel)\">{{ritdeelViewModel.isNieuw}}</td>\n                    <td id=\"ritdetails-r{{i}}-vanSpoor\" (click)=\"selectRitdeel($event, ritdeelViewModel.ritdeel)\">{{ritdeelViewModel.vanPrlSpoor}}</td>\n                    <td id=\"ritdetails-r{{i}}-naarSpoor\" (click)=\"selectRitdeel($event, ritdeelViewModel.ritdeel)\">{{ritdeelViewModel.naarPrlSpoor}}</td>\n                    <td id=\"ritdetails-r{{i}}-dwangNummer\" (click)=\"selectRitdeel($event, ritdeelViewModel.ritdeel)\">{{ritdeelViewModel.dwangNummer}}</td>\n                    <td id=\"ritdetails-r{{i}}-pplgs\" (click)=\"selectRitdeel($event, ritdeelViewModel.ritdeel)\">{{ritdeelViewModel.pplgString}}</td>\n                    <td id=\"ritdetails-r{{i}}-treinNummer\" (click)=\"selectRitdeel($event, ritdeelViewModel.ritdeel)\">{{ritdeelViewModel.treinNummer}}</td>\n                    <td style=\"text-align:right\">\n                        <button *ngIf=\"editable\"\n                                id=\"ritdetails-r{{i}}-del\"\n                                type=\"button\"\n                                class=\"loxia-btn loxia-btn-danger btn-sm\"\n                                (click)=\"deleteRitdeel(ritdeelViewModel.ritdeel)\">X\n                        </button>\n                    </td>\n                </tr>\n\n            </table>\n        </div>\n        <div class=\"actie-pane\">\n            <div *ngIf=\"selectedRitdeel  && (selectedRitdeelActies.length > 0 || selectedRitdeelOngeplandeActies.length > 0) \"\n                 id=\"actie-pane\">\n                <h4>Geplande acties</h4>\n                <table aria-hidden=\"true\">\n                    <tr>\n                        <th scope=\"col\">Actie</th>\n                        <th scope=\"col\">Van</th>\n                        <th scope=\"col\">Tot</th>\n                        <th scope=\"col\">\n                            <button *ngIf=\"editable\"\n                                    [hidden]=\"selectedRitdeelActies.length===0\"\n                                    id=\"bulkSetOngeplandButton\"\n                                    [attr.data-test-id]=\"'unplan-all-actions'\"\n                                    type=\"button\"\n                                    class=\"loxia-btn loxia-btn-danger btn-sm\"\n                                    (click)=\"deleteActiesUitRit()\"\n                                    [disabled]=\"disableActieKnoppenVanRitdeel\">X\n                            </button>\n                        </th>\n                    </tr>\n\n                    <tr *ngFor=\"let actie of selectedRitdeelActies; let i = index\" id=\"ritdetails-a{{i}}\">\n                        <td id=\"ritdetails-a{{i}}-omschrijving\" class=\"nowrap\">{{ actieOmschrijvingTekst(actie) }}</td>\n                        <td id=\"ritdetails-a{{i}}-vanKmLint\">{{ actieVanKmTekst(actie)}}</td>\n                        <td id=\"ritdetails-a{{i}}-totKmLint\">{{ actieTotKmTekst(actie)}}</td>\n                        <td style=\"text-align:right\">\n                            <button *ngIf=\"editable\"\n                                    id=\"ritdetails-a{{i}}-del\"\n                                    type=\"button\"\n                                    class=\"loxia-btn loxia-btn-danger btn-sm\"\n                                    (click)=\"deleteActieUitRit(actie)\"\n                                    [disabled]=\"disableActieKnoppenVanRitdeel\">X\n                            </button>\n                        </td>\n                    </tr>\n                </table>\n                <h4>Ongeplande acties</h4>\n                <table aria-hidden=\"true\">\n                    <tr>\n                        <th scope=\"col\">Actie</th>\n                        <th scope=\"col\">Van</th>\n                        <th scope=\"col\">Tot</th>\n                        <th scope=\"col\">\n                            <button *ngIf=\"editable\"\n                                    [hidden]=\"selectedRitdeelOngeplandeActies.length===0\"\n                                    id=\"bulkSetGeplandButton\"\n                                    [attr.data-test-id]=\"'plan-all-actions'\"\n                                    type=\"button\"\n                                    class=\"loxia-btn loxia-btn-success loxia-btn-sm\"\n                                    (click)=\"voegActiesToeAanRit()\"\n                                    [disabled]=\"disableActieKnoppenVanRitdeel\">^\n                            </button>\n                        </th>\n                    </tr>\n\n                    <tr *ngFor=\"let ongeplandeActie of selectedRitdeelOngeplandeActies; let i = index\"\n                        id=\"ritdetails-oa{{i}}\">\n                        <td id=\"ritdetails-oa{{i}}-omschrijving\" class=\"nowrap\">{{actieOmschrijvingTekst(ongeplandeActie.actie) }}</td>\n                        <td id=\"ritdetails-oa{{i}}-vanKmLint\">{{ actieVanKmTekst(ongeplandeActie.actie)}}</td>\n                        <td id=\"ritdetails-oa{{i}}-totKmLint\">{{ actieTotKmTekst(ongeplandeActie.actie)}}</td>\n                        <td style=\"text-align:right\">\n                            <button *ngIf=\"editable\"\n                                    id=\"ritdetails-oa{{i}}-del\"\n                                    type=\"button\"\n                                    class=\"loxia-btn loxia-btn-success loxia-btn-sm\"\n                                    (click)=\"voegActieToeAanRit(ongeplandeActie)\"\n                                    [disabled]=\"disableActieKnoppenVanRitdeel\">^\n                            </button>\n                        </td>\n                    </tr>\n                </table>\n            </div>\n        </div>\n        <div class=\"knop-pane\">\n            <button type=\"button\"\n                    class=\"loxia-btn loxia-btn-primary loxia-btn-sm\"\n                    [attr.data-test-id]=\"'plan-all-actions-for-file'\"\n                    [innerText]=\"'Plan acties hele rit'\"\n                    (click)=\"planAlleRitActies()\">\n            </button>\n        </div>\n    </div>\n</div>\n"]}