chore(scenery): improved thumbnails checkbox design and elements' padding

This commit is contained in:
2026-03-14 01:50:48 +01:00
parent 41dda1e592
commit c901b14715
@@ -1,7 +1,11 @@
<template> <template>
<div class="scenery-timetable-list"> <div class="scenery-timetable-list">
<!-- Checkpoints derived from station data --> <!-- Checkpoints derived from station data -->
<div class="timetable-checkpoints" v-if="station?.generalInfo?.checkpoints">
<div
class="timetable-checkpoints"
v-if="station?.generalInfo && station.generalInfo.checkpoints.length > 0"
>
<template v-for="(ch, i) in station.generalInfo.checkpoints" :key="i"> <template v-for="(ch, i) in station.generalInfo.checkpoints" :key="i">
<template v-if="i > 0">&bull;</template> <template v-if="i > 0">&bull;</template>
<router-link <router-link
@@ -15,7 +19,10 @@
</div> </div>
<!-- Missing checkpoints if scenery is not in database --> <!-- Missing checkpoints if scenery is not in database -->
<div class="timetable-checkpoints" v-else-if="onlineScenery"> <div
class="timetable-checkpoints"
v-else-if="onlineScenery && onlineScenery.missingCheckpoints.length > 0"
>
<template v-for="(ch, i) in onlineScenery.missingCheckpoints" :key="i"> <template v-for="(ch, i) in onlineScenery.missingCheckpoints" :key="i">
<template v-if="i > 0">&bull;</template> <template v-if="i > 0">&bull;</template>
<router-link <router-link
@@ -28,45 +35,47 @@
</template> </template>
</div> </div>
<div> <div class="timetable-options">
<input <div class="thumbnails-checkbox">
type="checkbox" <label>
name="show-stock-thumbnails" <input type="checkbox" v-model="showStockThumbnails" />
id="show-stock-thumbnails" <span>POKAZUJ PODGLĄDY SKŁADÓW</span>
v-model="showStockThumbnails" </label>
/> </div>
<label for="show-stock-thumbnails">POKAZUJ PODGLĄDY SKŁADÓW</label>
</div> </div>
<div class="list-container"> <div class="list-container">
<transition-group name="list-anim" tag="ul"> <transition-group name="list-anim">
<li <div
v-if="apiStore.dataStatuses.connection == 0 && sceneryTimetables.length == 0" v-if="apiStore.dataStatuses.connection == 0 && sceneryTimetables.length == 0"
style="padding-bottom: 5em" style="padding-bottom: 5em"
key="list-loading" key="list-loading"
> >
<Loading /> <Loading />
</li> </div>
<li <div
class="timetable-item empty" class="timetable-item empty"
v-else-if="sceneryTimetables.length == 0 && !onlineScenery" v-else-if="sceneryTimetables.length == 0 && !onlineScenery"
key="list-offline" key="list-offline"
> >
{{ $t('scenery.offline') }} {{ $t('scenery.offline') }}
</li> </div>
<li <div
class="timetable-item empty" class="timetable-item empty"
v-else-if="sceneryTimetables.length == 0" v-else-if="sceneryTimetables.length == 0"
key="list-no-timetables" key="list-no-timetables"
> >
{{ $t('scenery.no-timetables') }} {{ $t('scenery.no-timetables') }}
</li> </div>
<li v-else class="timetable-item" v-for="(row, i) in sceneryTimetables" :key="row.train.id"> <router-link
<!-- {{ row.train.id + row.checkpointStop.arrivalTimestamp.toString() }} --> v-for="row in sceneryTimetables"
<router-link class="item-link" tabindex="0" :to="row.train.driverRouteLocation"> class="timetable-item"
:to="row.train.driverRouteLocation"
:key="row.train.id"
>
<div class="item-top"> <div class="item-top">
<div class="top-general"> <div class="top-general">
<span class="general-info"> <span class="general-info">
@@ -187,9 +196,7 @@
<span class="departure-time" v-else> <span class="departure-time" v-else>
<div v-if="row.checkpointStop.departureDelay == 0"> <div v-if="row.checkpointStop.departureDelay == 0">
<span>{{ <span>{{ timestampToTimeString(row.checkpointStop.departureTimestamp) }}</span>
timestampToTimeString(row.checkpointStop.departureTimestamp)
}}</span>
</div> </div>
<div v-else> <div v-else>
<div> <div>
@@ -213,7 +220,6 @@
<StockList :trainStockList="row.train.stockList" /> <StockList :trainStockList="row.train.stockList" />
</div> </div>
</router-link> </router-link>
</li>
</transition-group> </transition-group>
</div> </div>
</div> </div>
@@ -306,7 +312,6 @@ const sceneryTimetables: ComputedRef<SceneryTimetableRow[]> = computed(() => {
display: grid; display: grid;
grid-template-rows: auto auto 1fr; grid-template-rows: auto auto 1fr;
overflow: hidden; overflow: hidden;
gap: 1em;
} }
.top-general { .top-general {
@@ -336,7 +341,7 @@ const sceneryTimetables: ComputedRef<SceneryTimetableRow[]> = computed(() => {
flex-wrap: wrap; flex-wrap: wrap;
font-size: 1.1em; font-size: 1.1em;
margin-top: 0.5em; margin: 0.5em 0;
} }
.checkpoint-item { .checkpoint-item {
@@ -353,21 +358,46 @@ const sceneryTimetables: ComputedRef<SceneryTimetableRow[]> = computed(() => {
} }
} }
.thumbnails-checkbox {
label {
cursor: pointer;
color: #aaa;
}
input {
width: 0;
outline: none;
}
input:checked + span {
color: var(--clr-success);
}
input:focus-visible + span {
outline: 1px solid white;
}
}
.list-container { .list-container {
position: relative; position: relative;
overflow-y: auto; overflow-y: auto;
overflow-x: hidden;
margin-top: 0.5em;
padding: 2px;
width: 100%;
} }
.timetable-item { .timetable-item {
margin: 0.5em 0; display: block;
margin-bottom: 0.5em;
padding: 0.35em; padding: 0.35em;
max-width: 1100px; width: 100%;
overflow: hidden; overflow: hidden;
background: #353535; background: #353535;
z-index: 10;
&.empty { &.empty {
padding: 1rem; padding: 1rem;
font-size: 1.2em; font-size: 1.2em;
@@ -375,13 +405,13 @@ const sceneryTimetables: ComputedRef<SceneryTimetableRow[]> = computed(() => {
} }
} }
.timetable-item > .item-link > .item-top { .timetable-item > .item-top {
display: grid; display: grid;
grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
gap: 1.2em 0.5em; gap: 1.2em 0.5em;
} }
.timetable-item > .item-link > .item-stock-list { .timetable-item > .item-stock-list {
margin-top: 1em; margin-top: 1em;
} }