mirror of
https://github.com/Spythere/stacjownik.git
synced 2026-05-03 13:28:11 +00:00
Compare commits
15 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| af6eb35b67 | |||
| 1e6ab1c2d1 | |||
| fd4849bd5e | |||
| bc0f4c5d3f | |||
| 8909a0cd40 | |||
| a2602aeefe | |||
| 37ad9b2787 | |||
| 0b4ad679b3 | |||
| dd0d7897cf | |||
| 1453dbda01 | |||
| 4af856b833 | |||
| 182b46a377 | |||
| bb5fc395d2 | |||
| a91a00f88a | |||
| c8d481a952 |
+1
-1
@@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "stacjownik",
|
"name": "stacjownik",
|
||||||
"version": "1.30.2",
|
"version": "1.30.3",
|
||||||
"private": true,
|
"private": true,
|
||||||
"type": "module",
|
"type": "module",
|
||||||
"scripts": {
|
"scripts": {
|
||||||
|
|||||||
@@ -1,5 +1,13 @@
|
|||||||
<template>
|
<template>
|
||||||
<section class="info-header">
|
<section class="info-header">
|
||||||
|
<button
|
||||||
|
class="btn btn-return"
|
||||||
|
:title="$t('scenery.return-btn')"
|
||||||
|
@click="onReturnButtonClick"
|
||||||
|
>
|
||||||
|
<img src="/images/icon-back.svg" alt="return button" />
|
||||||
|
</button>
|
||||||
|
|
||||||
<a class="scenery-name" :href="station?.generalInfo?.url" target="_blank">
|
<a class="scenery-name" :href="station?.generalInfo?.url" target="_blank">
|
||||||
{{ stationName.replace(/_/g, ' ') }}
|
{{ stationName.replace(/_/g, ' ') }}
|
||||||
</a>
|
</a>
|
||||||
@@ -12,39 +20,64 @@
|
|||||||
</section>
|
</section>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script lang="ts">
|
<script lang="ts" setup>
|
||||||
import { PropType, defineComponent } from 'vue';
|
import { onMounted, PropType, ref } from 'vue';
|
||||||
import { ActiveScenery, Station } from '../../typings/common';
|
import { ActiveScenery, Station } from '../../typings/common';
|
||||||
|
import { useRoute, useRouter } from 'vue-router';
|
||||||
|
|
||||||
export default defineComponent({
|
const route = useRoute();
|
||||||
props: {
|
const router = useRouter();
|
||||||
station: {
|
|
||||||
type: Object as PropType<Station>
|
|
||||||
},
|
|
||||||
|
|
||||||
stationName: {
|
const prevPath = ref('/');
|
||||||
type: String,
|
|
||||||
required: true
|
|
||||||
},
|
|
||||||
|
|
||||||
onlineScenery: {
|
onMounted(() => {
|
||||||
type: Object as PropType<ActiveScenery>
|
prevPath.value = (route.meta['prevPath'] as string) ?? '/';
|
||||||
}
|
});
|
||||||
|
|
||||||
|
defineProps({
|
||||||
|
station: {
|
||||||
|
type: Object as PropType<Station>
|
||||||
|
},
|
||||||
|
|
||||||
|
stationName: {
|
||||||
|
type: String,
|
||||||
|
required: true
|
||||||
|
},
|
||||||
|
|
||||||
|
onlineScenery: {
|
||||||
|
type: Object as PropType<ActiveScenery>
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
function onReturnButtonClick() {
|
||||||
|
router.push(prevPath.value);
|
||||||
|
}
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<style lang="scss" scoped>
|
<style lang="scss" scoped>
|
||||||
@use '../../styles/responsive';
|
@use '../../styles/responsive';
|
||||||
|
@use 'sass:color';
|
||||||
|
|
||||||
.info-header {
|
.btn-return {
|
||||||
margin-top: 1em;
|
$bgColor: #2b2b2b;
|
||||||
|
background-color: $bgColor;
|
||||||
|
margin-bottom: 0.5em;
|
||||||
|
|
||||||
|
img {
|
||||||
|
width: 2em;
|
||||||
|
}
|
||||||
|
|
||||||
|
&:hover {
|
||||||
|
background-color: color.adjust($color: $bgColor, $lightness: 15%);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.scenery-name {
|
.scenery-name {
|
||||||
font-weight: bold;
|
font-weight: bold;
|
||||||
font-size: 3em;
|
font-size: 3em;
|
||||||
|
|
||||||
|
text-align: center;
|
||||||
|
|
||||||
text-transform: uppercase;
|
text-transform: uppercase;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -58,4 +91,10 @@ export default defineComponent({
|
|||||||
color: #aaa;
|
color: #aaa;
|
||||||
font-size: 1.2em;
|
font-size: 1.2em;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@include responsive.smallScreen {
|
||||||
|
.scenery-name {
|
||||||
|
font-size: 2.5em;
|
||||||
|
}
|
||||||
|
}
|
||||||
</style>
|
</style>
|
||||||
|
|||||||
@@ -44,6 +44,7 @@
|
|||||||
{{ route.routeName }}
|
{{ route.routeName }}
|
||||||
</span>
|
</span>
|
||||||
<span v-if="route.routeSpeed" class="speed">{{ route.routeSpeed }}</span>
|
<span v-if="route.routeSpeed" class="speed">{{ route.routeSpeed }}</span>
|
||||||
|
<span v-if="route.routeSpeedExit" class="speed">| {{ route.routeSpeedExit }}</span>
|
||||||
<span v-if="route.routeLength" class="length">
|
<span v-if="route.routeLength" class="length">
|
||||||
{{ (route.routeLength / 1000).toFixed(1) + 'km' }}
|
{{ (route.routeLength / 1000).toFixed(1) + 'km' }}
|
||||||
</span>
|
</span>
|
||||||
|
|||||||
@@ -93,18 +93,56 @@
|
|||||||
<span class="timetable-general">
|
<span class="timetable-general">
|
||||||
<span class="general-info">
|
<span class="general-info">
|
||||||
<div class="info-train">
|
<div class="info-train">
|
||||||
<b
|
<!-- Cargo warnings & details badges -->
|
||||||
data-tooltip-type="BaseTooltip"
|
|
||||||
:data-tooltip-content="getCategoryExplanation(row.train.timetableData!.category)"
|
|
||||||
class="text--primary tooltip-help"
|
|
||||||
>
|
|
||||||
{{ row.train.timetableData!.category }}
|
|
||||||
</b>
|
|
||||||
<span> </span>
|
|
||||||
<b>{{ row.train.trainNo }}</b>
|
|
||||||
<span> • </span>
|
|
||||||
<span>{{ row.train.driverName }}</span>
|
|
||||||
<span
|
<span
|
||||||
|
class="train-badge twr"
|
||||||
|
v-if="row.train.timetableData!.twr"
|
||||||
|
data-tooltip-type="BaseTooltip"
|
||||||
|
:data-tooltip-content="$t('warnings.TWR')"
|
||||||
|
>
|
||||||
|
TWR
|
||||||
|
</span>
|
||||||
|
|
||||||
|
<span
|
||||||
|
class="train-badge tn"
|
||||||
|
v-if="row.train.timetableData!.hasDangerousCargo"
|
||||||
|
data-tooltip-type="BaseTooltip"
|
||||||
|
:data-tooltip-content="$t('warnings.TN')"
|
||||||
|
>
|
||||||
|
TN
|
||||||
|
</span>
|
||||||
|
|
||||||
|
<span
|
||||||
|
class="train-badge pn"
|
||||||
|
v-if="row.train.timetableData!.hasExtraDeliveries"
|
||||||
|
data-tooltip-type="BaseTooltip"
|
||||||
|
:data-tooltip-content="$t('warnings.PN')"
|
||||||
|
>
|
||||||
|
PN
|
||||||
|
</span>
|
||||||
|
|
||||||
|
<!-- Train info -->
|
||||||
|
<span>
|
||||||
|
<b
|
||||||
|
data-tooltip-type="BaseTooltip"
|
||||||
|
:data-tooltip-content="
|
||||||
|
getCategoryExplanation(row.train.timetableData!.category)
|
||||||
|
"
|
||||||
|
class="text--primary tooltip-help"
|
||||||
|
>
|
||||||
|
{{ row.train.timetableData!.category }}
|
||||||
|
</b>
|
||||||
|
|
||||||
|
<b> {{ row.train.trainNo }}</b>
|
||||||
|
</span>
|
||||||
|
<span>•</span>
|
||||||
|
<span>{{ row.train.driverName }}</span>
|
||||||
|
<span>•</span>
|
||||||
|
<b style="color: #ddd">{{ row.train.stockList[0] }}</b>
|
||||||
|
|
||||||
|
<!-- Train stop comments -->
|
||||||
|
<span
|
||||||
|
class="stop-comments-icon"
|
||||||
v-if="row.checkpointStop.comments"
|
v-if="row.checkpointStop.comments"
|
||||||
data-tooltip-type="BaseTooltip"
|
data-tooltip-type="BaseTooltip"
|
||||||
:data-tooltip-content="row.checkpointStop.comments"
|
:data-tooltip-content="row.checkpointStop.comments"
|
||||||
@@ -352,6 +390,7 @@ export default defineComponent({
|
|||||||
<style lang="scss" scoped>
|
<style lang="scss" scoped>
|
||||||
@use '../../styles/responsive';
|
@use '../../styles/responsive';
|
||||||
@use '../../styles/animations';
|
@use '../../styles/animations';
|
||||||
|
@use '../../styles/badge';
|
||||||
|
|
||||||
.scenery-timetable {
|
.scenery-timetable {
|
||||||
height: 100%;
|
height: 100%;
|
||||||
@@ -468,21 +507,31 @@ export default defineComponent({
|
|||||||
|
|
||||||
.general-info {
|
.general-info {
|
||||||
display: flex;
|
display: flex;
|
||||||
|
flex-direction: column;
|
||||||
flex-wrap: wrap;
|
flex-wrap: wrap;
|
||||||
|
}
|
||||||
|
|
||||||
.info-number {
|
.info-train {
|
||||||
color: var(--clr-primary);
|
display: flex;
|
||||||
}
|
flex-wrap: wrap;
|
||||||
|
gap: 0.25em;
|
||||||
|
}
|
||||||
|
|
||||||
.info-route {
|
.info-train > .train-badge {
|
||||||
width: 100%;
|
font-size: 0.85em;
|
||||||
}
|
}
|
||||||
|
|
||||||
img {
|
.info-number {
|
||||||
height: 0.9em;
|
color: var(--clr-primary);
|
||||||
vertical-align: middle;
|
}
|
||||||
margin: 0 0.25em;
|
|
||||||
}
|
.info-route {
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.stop-comments-icon > img {
|
||||||
|
width: 1.2em;
|
||||||
|
vertical-align: middle;
|
||||||
}
|
}
|
||||||
|
|
||||||
.schedule {
|
.schedule {
|
||||||
|
|||||||
@@ -2,11 +2,9 @@
|
|||||||
<div class="general-status">
|
<div class="general-status">
|
||||||
<span
|
<span
|
||||||
:class="computedScheduledTrain.status"
|
:class="computedScheduledTrain.status"
|
||||||
data-tooltip-type="HtmlTooltip"
|
|
||||||
:data-tooltip-content="computedScheduledTrain.stopStatusDescription"
|
|
||||||
@click.prevent="() => {}"
|
@click.prevent="() => {}"
|
||||||
|
v-html="computedScheduledTrain.stopStatusIndicator"
|
||||||
>
|
>
|
||||||
{{ computedScheduledTrain.stopStatusIndicator }}
|
|
||||||
</span>
|
</span>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
@@ -28,48 +26,37 @@ export default defineComponent({
|
|||||||
computedScheduledTrain() {
|
computedScheduledTrain() {
|
||||||
const { status, prevElement, currentElement, nextElement } = this.sceneryTimetableRow;
|
const { status, prevElement, currentElement, nextElement } = this.sceneryTimetableRow;
|
||||||
|
|
||||||
const prevDepartureIndicator = prevElement?.departureRouteExt
|
let stopStatusIndicator = '';
|
||||||
? `(${prevElement.departureRouteExt}) ${prevElement.stationName}`
|
|
||||||
: '---';
|
|
||||||
|
|
||||||
const nextArrivalIndicator = nextElement?.arrivalRouteExt
|
|
||||||
? `(${nextElement.arrivalRouteExt}) ${nextElement.stationName}`
|
|
||||||
: `${currentElement.stationName}`;
|
|
||||||
|
|
||||||
let stopStatusDescription = '',
|
|
||||||
stopStatusIndicator = '';
|
|
||||||
|
|
||||||
switch (status) {
|
switch (status) {
|
||||||
case StopStatus.ARRIVING:
|
case StopStatus.ARRIVING:
|
||||||
stopStatusIndicator = `${this.$t('timetables.from')}: ${prevDepartureIndicator}`;
|
if (prevElement) {
|
||||||
stopStatusDescription = this.$t('timetables.desc-arriving', {
|
stopStatusIndicator = this.$t('timetables.desc-arriving', {
|
||||||
prevStationName: prevElement?.stationName ?? '',
|
prevStationName: prevElement?.stationName ?? '',
|
||||||
prevDepartureLine: prevElement?.departureRouteExt ?? ''
|
prevDepartureLine: prevElement?.departureRouteExt ?? ''
|
||||||
});
|
});
|
||||||
|
} else {
|
||||||
|
stopStatusIndicator = this.$t('timetables.desc-beginning');
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case StopStatus.ONLINE:
|
case StopStatus.ONLINE:
|
||||||
case StopStatus.STOPPED:
|
case StopStatus.STOPPED:
|
||||||
stopStatusIndicator = nextElement?.arrivalRouteExt
|
stopStatusIndicator = nextElement?.arrivalRouteExt
|
||||||
? `${this.$t('timetables.to')}: ${nextArrivalIndicator}`
|
|
||||||
: `${this.$t('timetables.desc-end')}`;
|
|
||||||
stopStatusDescription = nextElement?.arrivalRouteExt
|
|
||||||
? this.$t(`timetables.desc-${status}`, {
|
? this.$t(`timetables.desc-${status}`, {
|
||||||
nextStationName: nextElement?.stationName,
|
nextStationName: nextElement?.stationName,
|
||||||
nextArrivalLine: nextElement?.arrivalRouteExt
|
nextArrivalLine: nextElement?.arrivalRouteExt
|
||||||
})
|
})
|
||||||
: '';
|
: this.$t(`timetables.desc-end`);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case StopStatus.DEPARTED:
|
case StopStatus.DEPARTED:
|
||||||
stopStatusIndicator = `${this.$t('timetables.to')}: ${nextArrivalIndicator}`;
|
|
||||||
|
|
||||||
if (!nextElement?.stationName) {
|
if (!nextElement?.stationName) {
|
||||||
stopStatusDescription = this.$t('timetables.desc-departed-ends', {
|
stopStatusIndicator = this.$t('timetables.desc-departed-ends', {
|
||||||
nextStationName: currentElement.stationName
|
nextStationName: currentElement.stationName
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
stopStatusDescription = this.$t('timetables.desc-departed', {
|
stopStatusIndicator = this.$t('timetables.desc-departed', {
|
||||||
nextStationName: nextElement?.stationName ?? currentElement.stationName,
|
nextStationName: nextElement?.stationName ?? currentElement.stationName,
|
||||||
nextArrivalLine: nextElement?.arrivalRouteExt
|
nextArrivalLine: nextElement?.arrivalRouteExt
|
||||||
});
|
});
|
||||||
@@ -78,16 +65,14 @@ export default defineComponent({
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case StopStatus.DEPARTED_AWAY:
|
case StopStatus.DEPARTED_AWAY:
|
||||||
stopStatusIndicator = `${this.$t('timetables.to')}: ${nextArrivalIndicator}`;
|
stopStatusIndicator = this.$t('timetables.desc-departed-away', {
|
||||||
stopStatusDescription = this.$t('timetables.desc-departed-away', {
|
|
||||||
nextStationName: nextElement?.stationName,
|
nextStationName: nextElement?.stationName,
|
||||||
nextArrivalLine: nextElement?.arrivalRouteExt
|
nextArrivalLine: nextElement?.arrivalRouteExt
|
||||||
});
|
});
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case StopStatus.TERMINATED:
|
case StopStatus.TERMINATED:
|
||||||
stopStatusIndicator = `X ${this.$t('timetables.desc-terminated')}`;
|
stopStatusIndicator = this.$t('timetables.desc-terminated');
|
||||||
stopStatusDescription = this.$t('timetables.desc-terminated');
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
@@ -95,7 +80,6 @@ export default defineComponent({
|
|||||||
}
|
}
|
||||||
return {
|
return {
|
||||||
...this.sceneryTimetableRow,
|
...this.sceneryTimetableRow,
|
||||||
stopStatusDescription,
|
|
||||||
stopStatusIndicator
|
stopStatusIndicator
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
@@ -106,7 +90,6 @@ export default defineComponent({
|
|||||||
<style lang="scss" scoped>
|
<style lang="scss" scoped>
|
||||||
.general-status {
|
.general-status {
|
||||||
margin-top: 0.5em;
|
margin-top: 0.5em;
|
||||||
cursor: help;
|
|
||||||
|
|
||||||
span.arriving {
|
span.arriving {
|
||||||
color: #ccc;
|
color: #ccc;
|
||||||
@@ -114,17 +97,14 @@ export default defineComponent({
|
|||||||
|
|
||||||
span.departed {
|
span.departed {
|
||||||
color: lime;
|
color: lime;
|
||||||
font-weight: bold;
|
|
||||||
|
|
||||||
&-away {
|
&-away {
|
||||||
font-weight: bold;
|
|
||||||
color: #5ecc5e;
|
color: #5ecc5e;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
span.stopped {
|
span.stopped {
|
||||||
color: #ffa600;
|
color: #ffa600;
|
||||||
font-weight: bold;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
span.online {
|
span.online {
|
||||||
@@ -133,7 +113,6 @@ export default defineComponent({
|
|||||||
|
|
||||||
span.terminated {
|
span.terminated {
|
||||||
color: salmon;
|
color: salmon;
|
||||||
font-weight: bold;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
</style>
|
</style>
|
||||||
|
|||||||
@@ -57,7 +57,14 @@
|
|||||||
<span>{{ stop.departureLine }}</span>
|
<span>{{ stop.departureLine }}</span>
|
||||||
|
|
||||||
<span v-if="stop.departureLineInfo">
|
<span v-if="stop.departureLineInfo">
|
||||||
<span> | {{ stop.departureLineInfo.routeSpeed }}</span>
|
<span>
|
||||||
|
|
|
||||||
|
{{
|
||||||
|
stop.departureLineInfo.routeSpeedExit
|
||||||
|
? `${stop.departureLineInfo.routeSpeedExit} (${stop.departureLineInfo.routeSpeed})`
|
||||||
|
: stop.departureLineInfo.routeSpeed
|
||||||
|
}}</span
|
||||||
|
>
|
||||||
|
|
||||||
<img
|
<img
|
||||||
:src="
|
:src="
|
||||||
@@ -85,13 +92,13 @@
|
|||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div
|
<div
|
||||||
v-if="stop.sceneryName != scheduleStops[i + 1]?.sceneryName"
|
v-if="stop.nextPointRef && stop.sceneryName != stop.nextPointRef.sceneryName"
|
||||||
class="scenery-change-name"
|
class="scenery-change-name"
|
||||||
>
|
>
|
||||||
<span>{{ scheduleStops[i + 1].sceneryName }}</span>
|
<span>{{ stop.nextPointRef.sceneryName }}</span>
|
||||||
|
|
||||||
<i
|
<i
|
||||||
v-if="!scheduleStops[i + 1].isSceneryOnline"
|
v-if="!stop.nextPointRef.isSceneryOnline"
|
||||||
class="fa-solid fa-ban fa-sm"
|
class="fa-solid fa-ban fa-sm"
|
||||||
data-tooltip-type="BaseTooltip"
|
data-tooltip-type="BaseTooltip"
|
||||||
:data-tooltip-content="$t('app.tooltip-scenery-offline')"
|
:data-tooltip-content="$t('app.tooltip-scenery-offline')"
|
||||||
@@ -101,30 +108,33 @@
|
|||||||
|
|
||||||
<div
|
<div
|
||||||
class="scenery-route"
|
class="scenery-route"
|
||||||
v-if="stop.sceneryName != scheduleStops[i + 1]?.sceneryName"
|
v-if="stop.nextPointRef && stop.sceneryName != stop.nextPointRef.sceneryName"
|
||||||
>
|
>
|
||||||
<span> {{ scheduleStops[i + 1].arrivalLine }}</span>
|
<span> {{ stop.nextPointRef.arrivalLine }}</span>
|
||||||
|
|
||||||
<span v-if="scheduleStops[i + 1].arrivalLineInfo">
|
<span v-if="stop.nextPointRef.arrivalLineInfo">
|
||||||
<span> | {{ scheduleStops[i + 1].arrivalLineInfo!.routeSpeed }} </span>
|
<span> | {{ stop.nextPointRef.arrivalLineInfo!.routeSpeed }}</span>
|
||||||
|
<span v-if="stop.nextPointRef.arrivalLineInfo!.routeSpeedExit"
|
||||||
|
>({{ stop.nextPointRef.arrivalLineInfo!.routeSpeedExit }})</span
|
||||||
|
>
|
||||||
|
|
||||||
<img
|
<img
|
||||||
:src="
|
:src="
|
||||||
scheduleStops[i + 1].arrivalLineInfo?.isElectric
|
stop.nextPointRef.arrivalLineInfo?.isElectric
|
||||||
? '/images/icon-catenary.svg'
|
? '/images/icon-catenary.svg'
|
||||||
: '/images/icon-we4a.png'
|
: '/images/icon-we4a.png'
|
||||||
"
|
"
|
||||||
data-tooltip-type="BaseTooltip"
|
data-tooltip-type="BaseTooltip"
|
||||||
:data-tooltip-content="
|
:data-tooltip-content="
|
||||||
$t(
|
$t(
|
||||||
`trains.${!scheduleStops[i + 1].arrivalLineInfo?.isElectric ? 'no-' : ''}catenary-tooltip`
|
`trains.${!stop.nextPointRef.arrivalLineInfo?.isElectric ? 'no-' : ''}catenary-tooltip`
|
||||||
)
|
)
|
||||||
"
|
"
|
||||||
width="14"
|
width="14"
|
||||||
/>
|
/>
|
||||||
|
|
||||||
<img
|
<img
|
||||||
v-if="scheduleStops[i + 1].arrivalLineInfo!.isRouteSBL"
|
v-if="stop.nextPointRef.arrivalLineInfo!.isRouteSBL"
|
||||||
src="/images/icon-sbl-transparent.svg"
|
src="/images/icon-sbl-transparent.svg"
|
||||||
width="14"
|
width="14"
|
||||||
data-tooltip-type="BaseTooltip"
|
data-tooltip-type="BaseTooltip"
|
||||||
@@ -228,7 +238,7 @@ export default defineComponent({
|
|||||||
departureLineInfo = pathData.departureLineData;
|
departureLineInfo = pathData.departureLineData;
|
||||||
}
|
}
|
||||||
|
|
||||||
for (const stop of followingStops) {
|
followingStops.forEach((stop, i) => {
|
||||||
let isExternal = false;
|
let isExternal = false;
|
||||||
|
|
||||||
if (stop.arrivalLine === currentPath.arrivalRouteExt) {
|
if (stop.arrivalLine === currentPath.arrivalRouteExt) {
|
||||||
@@ -287,7 +297,9 @@ export default defineComponent({
|
|||||||
status: stop.confirmed ? 'confirmed' : stop.stopped ? 'stopped' : 'unconfirmed',
|
status: stop.confirmed ? 'confirmed' : stop.stopped ? 'stopped' : 'unconfirmed',
|
||||||
|
|
||||||
sceneryName: currentPath.stationName,
|
sceneryName: currentPath.stationName,
|
||||||
isSceneryOnline: pathData?.isOnline ?? false
|
isSceneryOnline: pathData?.isOnline ?? false,
|
||||||
|
|
||||||
|
nextPointRef: null
|
||||||
};
|
};
|
||||||
|
|
||||||
if (internalRouteInfo) {
|
if (internalRouteInfo) {
|
||||||
@@ -309,6 +321,11 @@ export default defineComponent({
|
|||||||
|
|
||||||
stopRows.push(rowData);
|
stopRows.push(rowData);
|
||||||
|
|
||||||
|
// Assign this row data object to the last one as reference
|
||||||
|
if (i != 0) {
|
||||||
|
stopRows[i - 1].nextPointRef = rowData;
|
||||||
|
}
|
||||||
|
|
||||||
if (stop.departureLine === currentPath.departureRouteExt) {
|
if (stop.departureLine === currentPath.departureRouteExt) {
|
||||||
// Reverse search for last scenery checkpoint
|
// Reverse search for last scenery checkpoint
|
||||||
if (pathData?.departureLineData) {
|
if (pathData?.departureLineData) {
|
||||||
@@ -328,7 +345,7 @@ export default defineComponent({
|
|||||||
currentPath = timetablePath[++currentPathIndex];
|
currentPath = timetablePath[++currentPathIndex];
|
||||||
pathData = this.getPathSceneryData(currentPath);
|
pathData = this.getPathSceneryData(currentPath);
|
||||||
}
|
}
|
||||||
}
|
});
|
||||||
|
|
||||||
return stopRows;
|
return stopRows;
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -196,4 +196,6 @@ export interface TrainSchedulePoint {
|
|||||||
isSBL: boolean;
|
isSBL: boolean;
|
||||||
sceneryName: string | null;
|
sceneryName: string | null;
|
||||||
isSceneryOnline: boolean;
|
isSceneryOnline: boolean;
|
||||||
|
|
||||||
|
nextPointRef: TrainSchedulePoint | null;
|
||||||
}
|
}
|
||||||
@@ -22,7 +22,7 @@
|
|||||||
"TRE", "TRS",
|
"TRE", "TRS",
|
||||||
"TSE", "TSS",
|
"TSE", "TSS",
|
||||||
"THE", "THS",
|
"THE", "THS",
|
||||||
"LPE",
|
"LPE", "LPS",
|
||||||
"LTE", "LTS",
|
"LTE", "LTS",
|
||||||
"LSS",
|
"LSS",
|
||||||
"LZE", "LZS",
|
"LZE", "LZS",
|
||||||
|
|||||||
+12
-11
@@ -84,7 +84,7 @@
|
|||||||
"categories": {
|
"categories": {
|
||||||
"EI": "domestic express",
|
"EI": "domestic express",
|
||||||
"EC": "international express",
|
"EC": "international express",
|
||||||
"EN": "domestic night express",
|
"EN": "international night express",
|
||||||
"MP": "intervoivodeship bullet",
|
"MP": "intervoivodeship bullet",
|
||||||
"MO": "intervoivodeship regio",
|
"MO": "intervoivodeship regio",
|
||||||
"MM": "international bullet",
|
"MM": "international bullet",
|
||||||
@@ -543,7 +543,7 @@
|
|||||||
"no-users": "NO ACTIVE PLAYERS",
|
"no-users": "NO ACTIVE PLAYERS",
|
||||||
"no-spawns": "NO OPEN SPAWNS",
|
"no-spawns": "NO OPEN SPAWNS",
|
||||||
"no-scenery": "Oops! This scenery doesn't exist!",
|
"no-scenery": "Oops! This scenery doesn't exist!",
|
||||||
"return-btn": "Return",
|
"return-btn": "BACK TO THE LAST SITE",
|
||||||
"history-btn": "View the dispatcher history",
|
"history-btn": "View the dispatcher history",
|
||||||
"info-btn": "Return to the scenery view",
|
"info-btn": "Return to the scenery view",
|
||||||
"authors-title": "Scenery author | Scenery authors",
|
"authors-title": "Scenery author | Scenery authors",
|
||||||
@@ -589,15 +589,16 @@
|
|||||||
"terminated": "Timetable terminated",
|
"terminated": "Timetable terminated",
|
||||||
"begins": "BEGINS HERE",
|
"begins": "BEGINS HERE",
|
||||||
"terminates": "TERMINATES\nHERE",
|
"terminates": "TERMINATES\nHERE",
|
||||||
"from": "FROM",
|
"from": "Arrives from",
|
||||||
"to": "TO",
|
"to": "Departs to",
|
||||||
"desc-arriving": "The train is not here yet.\nIt's going to come from: <b>{prevStationName} (route {prevDepartureLine})</b>",
|
"desc-beginning": "The train begins here",
|
||||||
"desc-online": "The train is at the station.\nIt's going to leave to: <b>{nextStationName} (route {nextArrivalLine})</b>",
|
"desc-arriving": "<i>Arrives from: <b>{prevStationName} ({prevDepartureLine})</b></i>",
|
||||||
"desc-stopped": "The train is at the station and is stopped.\nIt's going to leave towards: <b>{nextStationName} (route {nextArrivalLine})</b>",
|
"desc-online": "On scenery / <i>direction: <b>{nextStationName} ({nextArrivalLine})</b></i>",
|
||||||
"desc-next-arrival": "Leaves towards: <b>{nextStationName} (route {nextArrivalLine})</b>",
|
"desc-stopped": "On scenery - stopped / <i>direction: <b>{nextStationName} ({nextArrivalLine})</b></i>",
|
||||||
"desc-departed": "The train is at the station and it's been departed.\nLeaves towards: <b>{nextStationName} (route {nextArrivalLine})</b>",
|
"desc-next-arrival": "On scenery / <i>direction: <b>{nextStationName} ({nextArrivalLine})</b></i>",
|
||||||
"desc-departed-ends": "The train is at the station and it's been departed.\nLeaves towards station: <b>{nextStationName}</b>",
|
"desc-departed": "On scenery / <i>departed to: <b>{nextStationName} ({nextArrivalLine})</b></i>",
|
||||||
"desc-departed-away": "The train has been departed to:\n<b>{nextStationName} (route {nextArrivalLine})</b>",
|
"desc-departed-ends": "On scenery / <i>departed to: <b>{nextStationName}</b></i>",
|
||||||
|
"desc-departed-away": "<i>Departed to: <b>{nextStationName} ({nextArrivalLine})</b></i>",
|
||||||
"desc-end": "The train terminates here",
|
"desc-end": "The train terminates here",
|
||||||
"desc-terminated": "The train has been terminated"
|
"desc-terminated": "The train has been terminated"
|
||||||
},
|
},
|
||||||
|
|||||||
+13
-12
@@ -81,7 +81,7 @@
|
|||||||
"categories": {
|
"categories": {
|
||||||
"EI": "ekspres krajowy",
|
"EI": "ekspres krajowy",
|
||||||
"EC": "ekspres międzynarodowy",
|
"EC": "ekspres międzynarodowy",
|
||||||
"EN": "ekspres krajowy nocny",
|
"EN": "ekspres międzynarodowy nocny",
|
||||||
"MP": "międzywojewódzki pospieszny",
|
"MP": "międzywojewódzki pospieszny",
|
||||||
"MO": "międzywojewódzki osobowy",
|
"MO": "międzywojewódzki osobowy",
|
||||||
"MM": "międzynarodowy pospieszny",
|
"MM": "międzynarodowy pospieszny",
|
||||||
@@ -529,7 +529,7 @@
|
|||||||
"no-users": "BRAK AKTYWNYCH GRACZY",
|
"no-users": "BRAK AKTYWNYCH GRACZY",
|
||||||
"no-spawns": "BRAK OTWARTYCH SPAWNÓW",
|
"no-spawns": "BRAK OTWARTYCH SPAWNÓW",
|
||||||
"no-scenery": "Ups! Ta sceneria nie istnieje!",
|
"no-scenery": "Ups! Ta sceneria nie istnieje!",
|
||||||
"return-btn": "Powrót",
|
"return-btn": "POWRÓT DO POPRZEDNIEJ STRONY",
|
||||||
"history-btn": "Przejdź do widoku historii dyżurnych ruchu",
|
"history-btn": "Przejdź do widoku historii dyżurnych ruchu",
|
||||||
"info-btn": "Wróć do widoku scenerii",
|
"info-btn": "Wróć do widoku scenerii",
|
||||||
"authors-title": "Autor scenerii | Autorzy scenerii",
|
"authors-title": "Autor scenerii | Autorzy scenerii",
|
||||||
@@ -575,17 +575,18 @@
|
|||||||
"terminated": "Rozkład jazdy zakończony",
|
"terminated": "Rozkład jazdy zakończony",
|
||||||
"begins": "ROZPOCZYNA\nBIEG",
|
"begins": "ROZPOCZYNA\nBIEG",
|
||||||
"terminates": "KOŃCZY BIEG",
|
"terminates": "KOŃCZY BIEG",
|
||||||
"from": "Z",
|
"from": "Przyjedzie z",
|
||||||
"to": "DO",
|
"to": "Odjeżdża do",
|
||||||
"desc-arriving": "Pociągu nie ma jeszcze na tej scenerii.\nPrzyjedzie z: <b>{prevStationName} (szlak {prevDepartureLine})</b>",
|
"desc-beginning": "Pociąg rozpoczyna bieg",
|
||||||
"desc-online": "Pociąg jest na tej scenerii.\nOdjedzie w kierunku: <b>{nextStationName} (szlak {nextArrivalLine})</b>",
|
"desc-arriving": "<i>Przyjedzie z: <b>{prevStationName} ({prevDepartureLine})</b></i>",
|
||||||
"desc-stopped": "Pociąg jest na tej scenerii i odbywa postój.\nOdjedzie w kierunku: <b>{nextStationName} (szlak {nextArrivalLine})</b>",
|
"desc-online": "Na scenerii / <i>kierunek: <b>{nextStationName} ({nextArrivalLine})</b></i>",
|
||||||
"desc-next-arrival": "Odjeżdża do:\n<b>{nextStationName} (szlak {nextArrivalLine})</b>",
|
"desc-stopped": "Na scenerii - postój / <i>kierunek: <b>{nextStationName} ({nextArrivalLine})</b></i>",
|
||||||
"desc-departed": "Pociąg jest na tej scenerii i został odprawiony.\nOdjeżdża w kierunku: <b>{nextStationName} (szlak {nextArrivalLine})</b>",
|
"desc-next-arrival": "Na scenerii / <i>kierunek: <b>{nextStationName} ({nextArrivalLine})</b></i>",
|
||||||
"desc-departed-ends": "Pociąg jest na tej scenerii i został odprawiony.\nOdjechał w kierunku stacji: <b>{nextStationName}</b>",
|
"desc-departed": "Na scenerii / <i>odprawiony do: <b>{nextStationName} ({nextArrivalLine})</b></i>",
|
||||||
"desc-departed-away": "Pociąg został odprawiony i odjechał do:\n<b>{nextStationName} (szlak {nextArrivalLine})</b>",
|
"desc-departed-ends": "Na scenerii / <i>odprawiony do: <b>{nextStationName}</b></i>",
|
||||||
|
"desc-departed-away": "<i>Odprawiony do: <b>{nextStationName} ({nextArrivalLine})</b></i>",
|
||||||
"desc-end": "Pociąg kończy bieg",
|
"desc-end": "Pociąg kończy bieg",
|
||||||
"desc-terminated": "Pociąg skończył bieg"
|
"desc-terminated": "Pociąg zakończył bieg"
|
||||||
},
|
},
|
||||||
"history": {
|
"history": {
|
||||||
"title": "DZIENNIK ROZKŁADÓW JAZDY"
|
"title": "DZIENNIK ROZKŁADÓW JAZDY"
|
||||||
|
|||||||
+5
-2
@@ -36,7 +36,10 @@ const routes: Array<RouteRecordRaw> = [
|
|||||||
props: (route) => ({
|
props: (route) => ({
|
||||||
region: route.query.region,
|
region: route.query.region,
|
||||||
station: route.query.station
|
station: route.query.station
|
||||||
})
|
}),
|
||||||
|
beforeEnter: (to, from) => {
|
||||||
|
to.meta['prevPath'] = from.fullPath;
|
||||||
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
path: '/journal',
|
path: '/journal',
|
||||||
@@ -72,7 +75,7 @@ const router = createRouter({
|
|||||||
from.query['view'] === undefined &&
|
from.query['view'] === undefined &&
|
||||||
!savedPosition
|
!savedPosition
|
||||||
)
|
)
|
||||||
return { el: `.scenery-left`, behavior: 'instant', top: 3 };
|
return { el: `.app_main`, behavior: 'instant', top: -13 };
|
||||||
|
|
||||||
if (savedPosition) return savedPosition;
|
if (savedPosition) return savedPosition;
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -297,48 +297,6 @@ a.a-button {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.return-btn {
|
|
||||||
display: none;
|
|
||||||
justify-content: center;
|
|
||||||
align-items: center;
|
|
||||||
|
|
||||||
position: fixed;
|
|
||||||
right: 2.5rem;
|
|
||||||
bottom: 4rem;
|
|
||||||
|
|
||||||
z-index: 100;
|
|
||||||
|
|
||||||
width: 3.5rem;
|
|
||||||
|
|
||||||
font-size: 3rem;
|
|
||||||
|
|
||||||
background-color: #555;
|
|
||||||
outline: 3px solid #222;
|
|
||||||
color: white;
|
|
||||||
|
|
||||||
border-radius: 50%;
|
|
||||||
cursor: pointer;
|
|
||||||
|
|
||||||
&:hover {
|
|
||||||
background-color: #3c3c3c;
|
|
||||||
}
|
|
||||||
|
|
||||||
img {
|
|
||||||
width: 1.3em;
|
|
||||||
}
|
|
||||||
|
|
||||||
@include responsive.smallScreen {
|
|
||||||
bottom: 1em;
|
|
||||||
right: 0;
|
|
||||||
left: 50%;
|
|
||||||
|
|
||||||
width: 1em;
|
|
||||||
height: 1em;
|
|
||||||
|
|
||||||
transform: translateX(-50%);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Basic tooltip
|
// Basic tooltip
|
||||||
[data-tooltip] {
|
[data-tooltip] {
|
||||||
cursor: help;
|
cursor: help;
|
||||||
|
|||||||
@@ -142,6 +142,7 @@ export interface StationRoutesInfo {
|
|||||||
isRouteSBL: boolean;
|
isRouteSBL: boolean;
|
||||||
routeLength: number;
|
routeLength: number;
|
||||||
routeSpeed: number;
|
routeSpeed: number;
|
||||||
|
routeSpeedExit?: number;
|
||||||
routeTracks: number;
|
routeTracks: number;
|
||||||
hidden?: boolean;
|
hidden?: boolean;
|
||||||
realLineNo?: number;
|
realLineNo?: number;
|
||||||
|
|||||||
+74
-128
@@ -2,12 +2,6 @@
|
|||||||
<div class="scenery-view">
|
<div class="scenery-view">
|
||||||
<div class="scenery-wrapper" ref="card-wrapper">
|
<div class="scenery-wrapper" ref="card-wrapper">
|
||||||
<div class="scenery-left">
|
<div class="scenery-left">
|
||||||
<div class="scenery-actions">
|
|
||||||
<button class="back-btn" :title="$t('scenery.return-btn')" @click="onReturnButtonClick">
|
|
||||||
<img src="/images/icon-back.svg" alt="return button" />
|
|
||||||
</button>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<SceneryHeader
|
<SceneryHeader
|
||||||
:stationName="station"
|
:stationName="station"
|
||||||
:station="stationInfo"
|
:station="stationInfo"
|
||||||
@@ -23,8 +17,8 @@
|
|||||||
v-for="(viewMode, i) in viewModes"
|
v-for="(viewMode, i) in viewModes"
|
||||||
:key="i"
|
:key="i"
|
||||||
class="btn btn--option"
|
class="btn btn--option"
|
||||||
:class="{ checked: currentMode == viewMode.component }"
|
:class="{ checked: currentMode == viewMode.component.name }"
|
||||||
@click="setViewMode(viewMode.component)"
|
@click="setViewMode(viewMode.component.name!)"
|
||||||
>
|
>
|
||||||
{{ $t(viewMode.id) }}
|
{{ $t(viewMode.id) }}
|
||||||
</button>
|
</button>
|
||||||
@@ -32,17 +26,17 @@
|
|||||||
|
|
||||||
<div
|
<div
|
||||||
v-if="
|
v-if="
|
||||||
apiStore.dataStatuses.sceneries == Status.Loading ||
|
apiStore.dataStatuses.sceneries == Status.Data.Loading ||
|
||||||
apiStore.dataStatuses.connection == Status.Loading
|
apiStore.dataStatuses.connection == Status.Data.Loading
|
||||||
"
|
"
|
||||||
></div>
|
></div>
|
||||||
|
|
||||||
<keep-alive v-else>
|
<keep-alive v-else>
|
||||||
<component
|
<component
|
||||||
:is="currentMode"
|
:is="currentViewComponent"
|
||||||
:onlineScenery="onlineSceneryInfo"
|
:onlineScenery="onlineSceneryInfo"
|
||||||
:station="stationInfo"
|
:station="stationInfo"
|
||||||
:key="currentMode"
|
:key="currentViewComponent.name"
|
||||||
></component>
|
></component>
|
||||||
</keep-alive>
|
</keep-alive>
|
||||||
</div>
|
</div>
|
||||||
@@ -50,141 +44,93 @@
|
|||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script lang="ts">
|
<script lang="ts" setup>
|
||||||
import { computed, defineComponent } from 'vue';
|
import { computed, onMounted } from 'vue';
|
||||||
import { useRoute } from 'vue-router';
|
import { useRoute, useRouter } from 'vue-router';
|
||||||
import routerMixin from '../mixins/routerMixin';
|
|
||||||
import { useMainStore } from '../store/mainStore';
|
import { useMainStore } from '../store/mainStore';
|
||||||
|
|
||||||
import SceneryInfo from '../components/SceneryView/SceneryInfo.vue';
|
import SceneryInfo from '../components/SceneryView/SceneryInfo.vue';
|
||||||
import SceneryHeader from '../components/SceneryView/SceneryHeader.vue';
|
import SceneryHeader from '../components/SceneryView/SceneryHeader.vue';
|
||||||
|
|
||||||
import SceneryTimetable from '../components/SceneryView/SceneryTimetable.vue';
|
import SceneryTimetable from '../components/SceneryView/SceneryTimetable.vue';
|
||||||
import SceneryTimetablesHistory from '../components/SceneryView/SceneryTimetablesHistory.vue';
|
import SceneryTimetablesHistory from '../components/SceneryView/SceneryTimetablesHistory.vue';
|
||||||
import SceneryDispatchersHistory from '../components/SceneryView/SceneryDispatchersHistory.vue';
|
import SceneryDispatchersHistory from '../components/SceneryView/SceneryDispatchersHistory.vue';
|
||||||
import ActionButton from '../components/Global/ActionButton.vue';
|
|
||||||
import { Status } from '../typings/common';
|
|
||||||
import { useApiStore } from '../store/apiStore';
|
import { useApiStore } from '../store/apiStore';
|
||||||
|
import { Status } from '../typings/common';
|
||||||
|
|
||||||
enum SceneryViewMode {
|
const route = useRoute();
|
||||||
'TIMETABLES_ACTIVE',
|
const router = useRouter();
|
||||||
'TIMETABLES_HISTORY',
|
|
||||||
'SCENERY_HISTORY'
|
|
||||||
}
|
|
||||||
|
|
||||||
export default defineComponent({
|
const props = defineProps({
|
||||||
name: 'SceneryView',
|
region: {
|
||||||
|
type: String,
|
||||||
components: {
|
required: false
|
||||||
SceneryInfo,
|
|
||||||
SceneryTimetable,
|
|
||||||
ActionButton,
|
|
||||||
SceneryHeader,
|
|
||||||
SceneryTimetablesHistory,
|
|
||||||
SceneryDispatchersHistory
|
|
||||||
},
|
},
|
||||||
|
|
||||||
props: {
|
station: {
|
||||||
region: {
|
type: String,
|
||||||
type: String,
|
required: true
|
||||||
required: false
|
|
||||||
},
|
|
||||||
|
|
||||||
station: {
|
|
||||||
type: String,
|
|
||||||
required: true
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
mixins: [routerMixin],
|
|
||||||
|
|
||||||
data: () => ({
|
|
||||||
store: useMainStore(),
|
|
||||||
apiStore: useApiStore(),
|
|
||||||
|
|
||||||
viewModes: [
|
|
||||||
{
|
|
||||||
id: 'scenery.option-active-timetables',
|
|
||||||
component: 'SceneryTimetable'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: 'scenery.option-timetables-history',
|
|
||||||
component: 'SceneryTimetablesHistory'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: 'scenery.option-dispatchers-history',
|
|
||||||
component: 'SceneryDispatchersHistory'
|
|
||||||
}
|
|
||||||
],
|
|
||||||
sceneryViewMode: SceneryViewMode,
|
|
||||||
selectedCheckpoint: '',
|
|
||||||
currentViewCompontent: 'SceneryTimetable',
|
|
||||||
onlineFrom: -1,
|
|
||||||
Status: Status.Data
|
|
||||||
}),
|
|
||||||
|
|
||||||
setup() {
|
|
||||||
const route = useRoute();
|
|
||||||
|
|
||||||
const isComponentVisible = computed(() => route.path === '/scenery');
|
|
||||||
|
|
||||||
return {
|
|
||||||
isComponentVisible
|
|
||||||
};
|
|
||||||
},
|
|
||||||
|
|
||||||
computed: {
|
|
||||||
currentMode() {
|
|
||||||
return this.$route.query.view?.toString() ?? 'SceneryTimetable';
|
|
||||||
},
|
|
||||||
|
|
||||||
stationInfo() {
|
|
||||||
return this.store.stationList.find(
|
|
||||||
(station) => station.name === this.station?.toString().replace(/_/g, ' ')
|
|
||||||
);
|
|
||||||
},
|
|
||||||
|
|
||||||
onlineSceneryInfo() {
|
|
||||||
return this.store.activeSceneryList.find(
|
|
||||||
(scenery) =>
|
|
||||||
scenery.name === this.station?.toString().replace(/_/g, ' ') &&
|
|
||||||
scenery.region == this.store.region.id
|
|
||||||
);
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
methods: {
|
|
||||||
setViewMode(componentName: string) {
|
|
||||||
this.$router.push({
|
|
||||||
path: this.$route.path,
|
|
||||||
query: {
|
|
||||||
...this.$route.query,
|
|
||||||
view: componentName
|
|
||||||
}
|
|
||||||
});
|
|
||||||
},
|
|
||||||
|
|
||||||
loadSelectedCheckpoint() {
|
|
||||||
if (!this.stationInfo?.generalInfo?.checkpoints) return;
|
|
||||||
if (this.stationInfo.generalInfo.checkpoints.length == 0) return;
|
|
||||||
this.selectedCheckpoint = this.stationInfo.generalInfo.checkpoints[0];
|
|
||||||
},
|
|
||||||
|
|
||||||
onReturnButtonClick() {
|
|
||||||
this.$router.back();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
const store = useMainStore();
|
||||||
|
const apiStore = useApiStore();
|
||||||
|
|
||||||
|
const viewModes = [
|
||||||
|
{
|
||||||
|
id: 'scenery.option-active-timetables',
|
||||||
|
component: SceneryTimetable
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: 'scenery.option-timetables-history',
|
||||||
|
component: SceneryTimetablesHistory
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: 'scenery.option-dispatchers-history',
|
||||||
|
component: SceneryDispatchersHistory
|
||||||
|
}
|
||||||
|
];
|
||||||
|
|
||||||
|
const currentMode = computed(() => {
|
||||||
|
return route.query.view?.toString() ?? 'SceneryTimetable';
|
||||||
|
});
|
||||||
|
|
||||||
|
const currentViewComponent = computed(() => {
|
||||||
|
return (
|
||||||
|
viewModes.find((mode) => mode.component.name == currentMode.value)?.component ??
|
||||||
|
SceneryTimetable
|
||||||
|
);
|
||||||
|
});
|
||||||
|
|
||||||
|
const stationInfo = computed(() => {
|
||||||
|
return store.stationList.find(
|
||||||
|
(station) => station.name === props.station?.toString().replace(/_/g, ' ')
|
||||||
|
);
|
||||||
|
});
|
||||||
|
|
||||||
|
const onlineSceneryInfo = computed(() => {
|
||||||
|
return store.activeSceneryList.find(
|
||||||
|
(scenery) =>
|
||||||
|
scenery.name === props.station?.toString().replace(/_/g, ' ') &&
|
||||||
|
scenery.region == store.region.id
|
||||||
|
);
|
||||||
|
});
|
||||||
|
|
||||||
|
function setViewMode(componentName: string) {
|
||||||
|
router.push({
|
||||||
|
path: route.path,
|
||||||
|
query: {
|
||||||
|
...route.query,
|
||||||
|
view: componentName
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<style lang="scss" scoped>
|
<style lang="scss" scoped>
|
||||||
@use '../styles/responsive';
|
@use '../styles/responsive';
|
||||||
|
|
||||||
button.back-btn {
|
|
||||||
img {
|
|
||||||
width: 2em;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.scenery {
|
.scenery {
|
||||||
&-view {
|
&-view {
|
||||||
display: flex;
|
display: flex;
|
||||||
|
|||||||
@@ -3202,7 +3202,7 @@ sharp@*, sharp@^0.33.5:
|
|||||||
|
|
||||||
showdown@^2.1.0:
|
showdown@^2.1.0:
|
||||||
version "2.1.0"
|
version "2.1.0"
|
||||||
resolved "https://registry.npmjs.org/showdown/-/showdown-2.1.0.tgz"
|
resolved "https://registry.yarnpkg.com/showdown/-/showdown-2.1.0.tgz#1251f5ed8f773f0c0c7bfc8e6fd23581f9e545c5"
|
||||||
integrity sha512-/6NVYu4U819R2pUIk79n67SYgJHWCce0a5xTP979WbNp0FL9MN1I1QK662IDU1b6JzKTvmhgI7T7JYIxBi3kMQ==
|
integrity sha512-/6NVYu4U819R2pUIk79n67SYgJHWCce0a5xTP979WbNp0FL9MN1I1QK662IDU1b6JzKTvmhgI7T7JYIxBi3kMQ==
|
||||||
dependencies:
|
dependencies:
|
||||||
commander "^9.0.0"
|
commander "^9.0.0"
|
||||||
|
|||||||
Reference in New Issue
Block a user