@loxia/mst-viewer 8.1.3-202512151220 → 8.1.3-202512160534
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/generated/openapi/api/api.mjs +23 -0
- package/esm2022/generated/openapi/api/appConfigController.service.mjs +140 -0
- package/esm2022/generated/openapi/api/appConfigController.serviceInterface.mjs +2 -0
- package/esm2022/generated/openapi/api/bewegingController.service.mjs +155 -0
- package/esm2022/generated/openapi/api/bewegingController.serviceInterface.mjs +2 -0
- package/esm2022/generated/openapi/api/class0BuildProperties.service.mjs +140 -0
- package/esm2022/generated/openapi/api/class0BuildProperties.serviceInterface.mjs +2 -0
- package/esm2022/generated/openapi/api/connectorController.service.mjs +146 -0
- package/esm2022/generated/openapi/api/connectorController.serviceInterface.mjs +2 -0
- package/esm2022/generated/openapi/api/logController.service.mjs +150 -0
- package/esm2022/generated/openapi/api/logController.serviceInterface.mjs +2 -0
- package/esm2022/generated/openapi/api/p21Controller.service.mjs +236 -0
- package/esm2022/generated/openapi/api/p21Controller.serviceInterface.mjs +2 -0
- package/esm2022/generated/openapi/api/sbController.service.mjs +202 -0
- package/esm2022/generated/openapi/api/sbController.serviceInterface.mjs +2 -0
- package/esm2022/generated/openapi/api.module.mjs +40 -0
- package/esm2022/generated/openapi/configuration.mjs +99 -0
- package/esm2022/generated/openapi/encoder.mjs +19 -0
- package/esm2022/generated/openapi/index.mjs +7 -0
- package/esm2022/generated/openapi/model/actieDto.mjs +13 -0
- package/esm2022/generated/openapi/model/algemeneRitDto.mjs +13 -0
- package/esm2022/generated/openapi/model/bewegingDto.mjs +2 -0
- package/esm2022/generated/openapi/model/frontendKeycloakConfig.mjs +13 -0
- package/esm2022/generated/openapi/model/frontendProperties.mjs +2 -0
- package/esm2022/generated/openapi/model/logDto.mjs +2 -0
- package/esm2022/generated/openapi/model/models.mjs +10 -0
- package/esm2022/generated/openapi/model/ritRequestDto.mjs +2 -0
- package/esm2022/generated/openapi/model/signaleringsbeeldDto.mjs +13 -0
- package/esm2022/generated/openapi/model/signaleringsbeeldRequestDto.mjs +13 -0
- package/esm2022/generated/openapi/param.mjs +2 -0
- package/esm2022/generated/openapi/variables.mjs +9 -0
- package/esm2022/generated.version.mjs +2 -0
- package/esm2022/lib/atomic-components/message/index.mjs +4 -0
- package/esm2022/lib/atomic-components/message/message.component.mjs +34 -0
- package/esm2022/lib/atomic-components/message/message.mjs +8 -0
- package/esm2022/lib/atomic-components/message/severity.enum.mjs +9 -0
- package/esm2022/lib/atomic-components/messages/messages.component.mjs +20 -0
- package/esm2022/lib/atomic-components/overlay/overlay.component.mjs +11 -0
- package/esm2022/lib/atomic-components/progress-indicator/progress-indicator.component.mjs +11 -0
- package/esm2022/lib/atomic-components/progress-indicator/progress-indicator.entity.mjs +8 -0
- package/esm2022/lib/atomic-components/services/messages.service.mjs +27 -0
- package/esm2022/lib/components/carousel-controls/carousel-controls.component.mjs +40 -0
- package/esm2022/lib/components/mstviewer/mstviewer.component.mjs +110 -0
- package/esm2022/lib/components/ritdelen-lijst/ritdelen-lijst.component.mjs +267 -0
- package/esm2022/lib/components/ritdelen-view/ritdelen-view.component.mjs +103 -0
- package/esm2022/lib/components/rpe/rpe.component.mjs +33 -0
- package/esm2022/lib/components/svg-visualisatie/svg-visualisatie.component.mjs +273 -0
- package/esm2022/lib/components/viewer-controls/viewer-controls.component.mjs +52 -0
- package/esm2022/lib/model/alternatief-rit-deel.mjs +7 -0
- package/esm2022/lib/model/km-range.mjs +39 -0
- package/esm2022/lib/model/melding-event.mjs +7 -0
- package/esm2022/lib/model/nieuwe-route.mjs +10 -0
- package/esm2022/lib/model/ongeplande-actie.mjs +7 -0
- package/esm2022/lib/model/rijwegplan-rijweg-dwang-combinatie.mjs +24 -0
- package/esm2022/lib/model/ritdeel.mjs +205 -0
- package/esm2022/lib/model/sein-op-ritdeel.mjs +7 -0
- package/esm2022/lib/model/wissel-kant-code.mjs +7 -0
- package/esm2022/lib/mst-viewer.module.mjs +143 -0
- package/esm2022/lib/optimo.mjs +9 -0
- package/esm2022/lib/resources/mstlogging.resource.mjs +25 -0
- package/esm2022/lib/resources/signaleringsbeeldinfo.resource.mjs +62 -0
- package/esm2022/lib/services/base-rest.service.mjs +26 -0
- package/esm2022/lib/services/beweging-utils.service.mjs +139 -0
- package/esm2022/lib/services/beweging-verrijker.service.mjs +30 -0
- package/esm2022/lib/services/connector.service.mjs +30 -0
- package/esm2022/lib/services/debug.service.mjs +59 -0
- package/esm2022/lib/services/editor.service.mjs +48 -0
- package/esm2022/lib/services/print-beweging.service.mjs +66 -0
- package/esm2022/lib/services/rit-lezer.service.mjs +104 -0
- package/esm2022/lib/services/signalerings-beeld-manager.service.mjs +92 -0
- package/esm2022/lib/services/viewer-control.service.mjs +104 -0
- package/esm2022/lib/state/actions/actions.mjs +130 -0
- package/esm2022/lib/state/actions/ritdelen.actions.mjs +45 -0
- package/esm2022/lib/state/effect/bepaal-ongeplande-acties.effect.mjs +78 -0
- package/esm2022/lib/state/effect/bepaal-sb-infos.effect.mjs +67 -0
- package/esm2022/lib/state/effect/beweging-invoegen.effect.mjs +73 -0
- package/esm2022/lib/state/effect/delete-ongeplande-actie.effect.mjs +39 -0
- package/esm2022/lib/state/effect/focus-effect.mjs +36 -0
- package/esm2022/lib/state/effect/laad-route-files.effect.mjs +64 -0
- package/esm2022/lib/state/effect/laad-signaleringsbeelden.effect.mjs +363 -0
- package/esm2022/lib/state/effect/rit-goedkeuren.effect.mjs +23 -0
- package/esm2022/lib/state/effect/ritdelen.effect.mjs +112 -0
- package/esm2022/lib/state/effect/svg-view.effect.mjs +48 -0
- package/esm2022/lib/state/mst-editor-state.mjs +89 -0
- package/esm2022/lib/state/reducer/rit-delen.reducer.mjs +62 -0
- package/esm2022/lib/util/actie-helper.mjs +437 -0
- package/esm2022/lib/util/actie-popover-bepaler.mjs +90 -0
- package/esm2022/lib/util/date.service.mjs +17 -0
- package/esm2022/lib/util/logging-helper.mjs +58 -0
- package/esm2022/lib/util/melding-builder.mjs +13 -0
- package/esm2022/lib/util/message-builder.mjs +32 -0
- package/esm2022/lib/util/multi-map.mjs +76 -0
- package/esm2022/lib/util/utils.mjs +35 -0
- package/esm2022/lib/util/zone-util.mjs +32 -0
- package/esm2022/loxia-mst-viewer.mjs +5 -0
- package/esm2022/public-api.mjs +9 -0
- package/esm2022/src/generated/openapi/api/api.mjs +23 -0
- package/esm2022/src/generated/openapi/api/appConfigController.service.mjs +140 -0
- package/esm2022/src/generated/openapi/api/appConfigController.serviceInterface.mjs +2 -0
- package/esm2022/src/generated/openapi/api/bewegingController.service.mjs +155 -0
- package/esm2022/src/generated/openapi/api/bewegingController.serviceInterface.mjs +2 -0
- package/esm2022/src/generated/openapi/api/class0BuildProperties.service.mjs +140 -0
- package/esm2022/src/generated/openapi/api/class0BuildProperties.serviceInterface.mjs +2 -0
- package/esm2022/src/generated/openapi/api/connectorController.service.mjs +146 -0
- package/esm2022/src/generated/openapi/api/connectorController.serviceInterface.mjs +2 -0
- package/esm2022/src/generated/openapi/api/logController.service.mjs +150 -0
- package/esm2022/src/generated/openapi/api/logController.serviceInterface.mjs +2 -0
- package/esm2022/src/generated/openapi/api/p21Controller.service.mjs +236 -0
- package/esm2022/src/generated/openapi/api/p21Controller.serviceInterface.mjs +2 -0
- package/esm2022/src/generated/openapi/api/sbController.service.mjs +202 -0
- package/esm2022/src/generated/openapi/api/sbController.serviceInterface.mjs +2 -0
- package/esm2022/src/generated/openapi/api.module.mjs +40 -0
- package/esm2022/src/generated/openapi/configuration.mjs +99 -0
- package/esm2022/src/generated/openapi/encoder.mjs +19 -0
- package/esm2022/src/generated/openapi/index.mjs +7 -0
- package/esm2022/src/generated/openapi/loxia-mst-viewer-src-generated-openapi.mjs +5 -0
- package/esm2022/src/generated/openapi/model/actieDto.mjs +13 -0
- package/esm2022/src/generated/openapi/model/algemeneRitDto.mjs +13 -0
- package/esm2022/src/generated/openapi/model/bewegingDto.mjs +2 -0
- package/esm2022/src/generated/openapi/model/frontendKeycloakConfig.mjs +13 -0
- package/esm2022/src/generated/openapi/model/frontendProperties.mjs +2 -0
- package/esm2022/src/generated/openapi/model/logDto.mjs +2 -0
- package/esm2022/src/generated/openapi/model/models.mjs +10 -0
- package/esm2022/src/generated/openapi/model/ritRequestDto.mjs +2 -0
- package/esm2022/src/generated/openapi/model/signaleringsbeeldDto.mjs +13 -0
- package/esm2022/src/generated/openapi/model/signaleringsbeeldRequestDto.mjs +13 -0
- package/esm2022/src/generated/openapi/param.mjs +2 -0
- package/esm2022/src/generated/openapi/variables.mjs +9 -0
- package/fesm2022/loxia-mst-viewer-src-generated-openapi.mjs +25 -25
- package/fesm2022/loxia-mst-viewer-src-generated-openapi.mjs.map +1 -1
- package/fesm2022/loxia-mst-viewer.mjs +154 -154
- package/fesm2022/loxia-mst-viewer.mjs.map +1 -1
- package/generated/openapi/api/api.d.ts +22 -0
- package/generated/openapi/api/appConfigController.service.d.ts +38 -0
- package/generated/openapi/api/appConfigController.serviceInterface.d.ts +24 -0
- package/generated/openapi/api/bewegingController.service.d.ts +40 -0
- package/generated/openapi/api/bewegingController.serviceInterface.d.ts +27 -0
- package/generated/openapi/api/class0BuildProperties.service.d.ts +36 -0
- package/generated/openapi/api/class0BuildProperties.serviceInterface.d.ts +23 -0
- package/generated/openapi/api/connectorController.service.d.ts +38 -0
- package/generated/openapi/api/connectorController.serviceInterface.d.ts +25 -0
- package/generated/openapi/api/logController.service.d.ts +38 -0
- package/generated/openapi/api/logController.serviceInterface.d.ts +25 -0
- package/generated/openapi/api/p21Controller.service.d.ts +62 -0
- package/generated/openapi/api/p21Controller.serviceInterface.d.ts +30 -0
- package/generated/openapi/api/sbController.service.d.ts +60 -0
- package/generated/openapi/api/sbController.serviceInterface.d.ts +32 -0
- package/generated/openapi/api.module.d.ts +11 -0
- package/generated/openapi/configuration.d.ts +104 -0
- package/generated/openapi/encoder.d.ts +11 -0
- package/generated/openapi/index.d.ts +6 -0
- package/generated/openapi/model/actieDto.d.ts +35 -0
- package/generated/openapi/model/algemeneRitDto.d.ts +28 -0
- package/generated/openapi/model/bewegingDto.d.ts +37 -0
- package/generated/openapi/model/frontendKeycloakConfig.d.ts +16 -0
- package/generated/openapi/model/frontendProperties.d.ts +15 -0
- package/generated/openapi/model/logDto.d.ts +22 -0
- package/generated/openapi/model/models.d.ts +9 -0
- package/generated/openapi/model/ritRequestDto.d.ts +17 -0
- package/generated/openapi/model/signaleringsbeeldDto.d.ts +16 -0
- package/generated/openapi/model/signaleringsbeeldRequestDto.d.ts +16 -0
- package/generated/openapi/param.d.ts +37 -0
- package/generated/openapi/variables.d.ts +8 -0
- package/generated.version.d.ts +1 -0
- package/index.d.ts +3 -1079
- package/lib/atomic-components/message/index.d.ts +3 -0
- package/lib/atomic-components/message/message.component.d.ts +12 -0
- package/lib/atomic-components/message/message.d.ts +7 -0
- package/lib/atomic-components/message/severity.enum.d.ts +7 -0
- package/lib/atomic-components/messages/messages.component.d.ts +9 -0
- package/lib/atomic-components/overlay/overlay.component.d.ts +5 -0
- package/lib/atomic-components/progress-indicator/progress-indicator.component.d.ts +5 -0
- package/lib/atomic-components/progress-indicator/progress-indicator.entity.d.ts +6 -0
- package/lib/atomic-components/services/messages.service.d.ts +12 -0
- package/lib/components/carousel-controls/carousel-controls.component.d.ts +21 -0
- package/lib/components/mstviewer/mstviewer.component.d.ts +39 -0
- package/lib/components/ritdelen-lijst/ritdelen-lijst.component.d.ts +72 -0
- package/lib/components/ritdelen-view/ritdelen-view.component.d.ts +33 -0
- package/lib/components/rpe/rpe.component.d.ts +11 -0
- package/lib/components/svg-visualisatie/svg-visualisatie.component.d.ts +55 -0
- package/lib/components/viewer-controls/viewer-controls.component.d.ts +27 -0
- package/lib/model/alternatief-rit-deel.d.ts +7 -0
- package/lib/model/km-range.d.ts +13 -0
- package/lib/model/melding-event.d.ts +5 -0
- package/lib/model/nieuwe-route.d.ts +8 -0
- package/lib/model/ongeplande-actie.d.ts +6 -0
- package/lib/model/rijwegplan-rijweg-dwang-combinatie.d.ts +12 -0
- package/lib/model/ritdeel.d.ts +61 -0
- package/lib/model/sein-op-ritdeel.d.ts +7 -0
- package/lib/model/wissel-kant-code.d.ts +5 -0
- package/lib/mst-viewer.module.d.ts +34 -0
- package/lib/optimo.d.ts +69 -0
- package/lib/resources/mstlogging.resource.d.ts +15 -0
- package/lib/resources/signaleringsbeeldinfo.resource.d.ts +36 -0
- package/lib/services/base-rest.service.d.ts +16 -0
- package/lib/services/beweging-utils.service.d.ts +25 -0
- package/lib/services/beweging-verrijker.service.d.ts +11 -0
- package/lib/services/connector.service.d.ts +10 -0
- package/lib/services/debug.service.d.ts +15 -0
- package/lib/services/editor.service.d.ts +23 -0
- package/lib/services/print-beweging.service.d.ts +18 -0
- package/lib/services/rit-lezer.service.d.ts +22 -0
- package/lib/services/signalerings-beeld-manager.service.d.ts +29 -0
- package/lib/services/viewer-control.service.d.ts +32 -0
- package/lib/state/actions/actions.d.ts +275 -0
- package/lib/state/actions/ritdelen.actions.d.ts +101 -0
- package/lib/state/effect/bepaal-ongeplande-acties.effect.d.ts +23 -0
- package/lib/state/effect/bepaal-sb-infos.effect.d.ts +23 -0
- package/lib/state/effect/beweging-invoegen.effect.d.ts +17 -0
- package/lib/state/effect/delete-ongeplande-actie.effect.d.ts +15 -0
- package/lib/state/effect/focus-effect.d.ts +17 -0
- package/lib/state/effect/laad-route-files.effect.d.ts +28 -0
- package/lib/state/effect/laad-signaleringsbeelden.effect.d.ts +58 -0
- package/lib/state/effect/rit-goedkeuren.effect.d.ts +17 -0
- package/lib/state/effect/ritdelen.effect.d.ts +32 -0
- package/lib/state/effect/svg-view.effect.d.ts +17 -0
- package/lib/state/mst-editor-state.d.ts +133 -0
- package/lib/state/reducer/rit-delen.reducer.d.ts +4 -0
- package/lib/util/actie-helper.d.ts +117 -0
- package/lib/util/actie-popover-bepaler.d.ts +14 -0
- package/lib/util/date.service.d.ts +6 -0
- package/lib/util/logging-helper.d.ts +15 -0
- package/lib/util/melding-builder.d.ts +8 -0
- package/lib/util/message-builder.d.ts +13 -0
- package/lib/util/multi-map.d.ts +39 -0
- package/lib/util/utils.d.ts +4 -0
- package/lib/util/zone-util.d.ts +11 -0
- package/package.json +10 -6
- package/public-api.d.ts +5 -0
- package/src/generated/openapi/api/api.d.ts +22 -0
- package/src/generated/openapi/api/appConfigController.service.d.ts +38 -0
- package/src/generated/openapi/api/appConfigController.serviceInterface.d.ts +24 -0
- package/src/generated/openapi/api/bewegingController.service.d.ts +40 -0
- package/src/generated/openapi/api/bewegingController.serviceInterface.d.ts +27 -0
- package/src/generated/openapi/api/class0BuildProperties.service.d.ts +36 -0
- package/src/generated/openapi/api/class0BuildProperties.serviceInterface.d.ts +23 -0
- package/src/generated/openapi/api/connectorController.service.d.ts +38 -0
- package/src/generated/openapi/api/connectorController.serviceInterface.d.ts +25 -0
- package/src/generated/openapi/api/logController.service.d.ts +38 -0
- package/src/generated/openapi/api/logController.serviceInterface.d.ts +25 -0
- package/src/generated/openapi/api/p21Controller.service.d.ts +62 -0
- package/src/generated/openapi/api/p21Controller.serviceInterface.d.ts +30 -0
- package/src/generated/openapi/api/sbController.service.d.ts +60 -0
- package/src/generated/openapi/api/sbController.serviceInterface.d.ts +32 -0
- package/src/generated/openapi/api.module.d.ts +11 -0
- package/src/generated/openapi/configuration.d.ts +104 -0
- package/src/generated/openapi/encoder.d.ts +11 -0
- package/src/generated/openapi/index.d.ts +6 -825
- package/src/generated/openapi/model/actieDto.d.ts +35 -0
- package/src/generated/openapi/model/algemeneRitDto.d.ts +28 -0
- package/src/generated/openapi/model/bewegingDto.d.ts +37 -0
- package/src/generated/openapi/model/frontendKeycloakConfig.d.ts +16 -0
- package/src/generated/openapi/model/frontendProperties.d.ts +15 -0
- package/src/generated/openapi/model/logDto.d.ts +22 -0
- package/src/generated/openapi/model/models.d.ts +9 -0
- package/src/generated/openapi/model/ritRequestDto.d.ts +17 -0
- package/src/generated/openapi/model/signaleringsbeeldDto.d.ts +16 -0
- package/src/generated/openapi/model/signaleringsbeeldRequestDto.d.ts +16 -0
- package/src/generated/openapi/param.d.ts +37 -0
- package/src/generated/openapi/variables.d.ts +8 -0
- package/tailwind.scss +5 -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()\">×</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()\">×</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"]}
|