mirror of
https://github.com/Spythere/pojazdownik.git
synced 2026-05-03 19:48:11 +00:00
172 lines
4.0 KiB
Vue
172 lines
4.0 KiB
Vue
<template>
|
|
<section class="train-image-section">
|
|
<div class="train-image__content" :class="{ sponsor: store.chosenVehicle?.isSponsorsOnly }">
|
|
<img
|
|
tabindex="0"
|
|
:src="store.chosenVehicle ? getThumbnailURL(store.chosenVehicle.type, 'small') : '/images/placeholder.jpg'"
|
|
@click="onImageClick"
|
|
@keydown.enter="onImageClick"
|
|
@error="onImageError"
|
|
type="image/jpeg"
|
|
/>
|
|
</div>
|
|
|
|
<div class="train-image__info" v-if="store.chosenVehicle">
|
|
<b class="text--accent">{{ store.chosenVehicle.type }}</b> •
|
|
<b style="color: #ccc">
|
|
{{ $t(`preview.${isLocomotive(store.chosenVehicle) ? store.chosenVehicle.power : store.chosenVehicle.useType}`) }}
|
|
</b>
|
|
|
|
<div style="color: #ccc">
|
|
<div>{{ store.chosenVehicle.length }}m | {{ (store.chosenVehicle.weight / 1000).toFixed(1) }}t | {{ store.chosenVehicle.maxSpeed }} km/h</div>
|
|
|
|
<div v-if="isLocomotive(store.chosenVehicle)">{{ $t('preview.cabin') }} {{ store.chosenVehicle.cabinType }}</div>
|
|
|
|
<div v-else>
|
|
{{
|
|
store.chosenVehicle.useType == 'car-cargo'
|
|
? $t(`usage.${store.chosenVehicle.constructionType}`)
|
|
: `${$t('preview.construction')} ${store.chosenVehicle.constructionType}`
|
|
}}
|
|
</div>
|
|
|
|
<b style="color: salmon" v-if="store.chosenVehicle.isSponsorsOnly">{{
|
|
$t('preview.sponsor-only', [
|
|
new Date(store.chosenVehicle.sponsorsOnlyTimestamp).toLocaleDateString($i18n.locale == 'pl' ? 'pl-PL' : 'en-GB'),
|
|
])
|
|
}}</b>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="train-image__info" v-else>{{ $t('preview.desc') }}</div>
|
|
</section>
|
|
</template>
|
|
|
|
<script lang="ts">
|
|
import { computed, defineComponent } from 'vue';
|
|
import { useStore } from '../../store';
|
|
import { isLocomotive } from '../../utils/vehicleUtils';
|
|
import { ILocomotive, Vehicle } from '../../types';
|
|
import imageMixin from '../../mixins/imageMixin';
|
|
|
|
export default defineComponent({
|
|
mixins: [imageMixin],
|
|
|
|
data() {
|
|
return {
|
|
noImageAvailable: false,
|
|
};
|
|
},
|
|
|
|
setup() {
|
|
const store = useStore();
|
|
|
|
return {
|
|
store,
|
|
chosenVehicle: computed(() => store.chosenVehicle),
|
|
};
|
|
},
|
|
|
|
watch: {
|
|
chosenVehicle(vehicle: Vehicle, prevVehicle: Vehicle) {
|
|
if (vehicle && vehicle.type != prevVehicle?.type) {
|
|
this.store.imageLoading = true;
|
|
}
|
|
},
|
|
},
|
|
|
|
methods: {
|
|
onImageLoad() {
|
|
this.store.imageLoading = false;
|
|
},
|
|
|
|
onImageError(e: Event) {
|
|
const el = e.target as HTMLImageElement;
|
|
if (el.src == '/images/placeholder.jpg') return;
|
|
|
|
el.src = '/images/placeholder.jpg';
|
|
},
|
|
|
|
isLocomotive(vehicle: Vehicle): vehicle is ILocomotive {
|
|
return isLocomotive(vehicle);
|
|
},
|
|
|
|
onImageClick(e: Event) {
|
|
const target = e.target as HTMLElement;
|
|
|
|
const chosenVehicle = this.store.chosenVehicle;
|
|
|
|
if (!chosenVehicle) return;
|
|
|
|
this.store.lastFocusedElement = target;
|
|
this.store.vehiclePreviewSrc = this.getThumbnailURL(chosenVehicle.type, 'large');
|
|
},
|
|
},
|
|
});
|
|
</script>
|
|
|
|
<style lang="scss" scoped>
|
|
@import '../../styles/global.scss';
|
|
|
|
.train-image-section {
|
|
display: flex;
|
|
flex-direction: column;
|
|
text-align: center;
|
|
|
|
grid-row: 3;
|
|
grid-column: 1;
|
|
|
|
margin-top: 1em;
|
|
height: 22em;
|
|
}
|
|
|
|
.train-image {
|
|
&__content {
|
|
&.sponsor img {
|
|
border: 1px solid salmon;
|
|
}
|
|
|
|
img {
|
|
max-width: 380px;
|
|
width: 100%;
|
|
height: 100%;
|
|
border: 1px solid white;
|
|
|
|
cursor: zoom-in;
|
|
}
|
|
}
|
|
}
|
|
|
|
.train-image__info {
|
|
font-size: 1.1em;
|
|
padding: 0.5em;
|
|
margin: 0.5em auto;
|
|
line-height: 1.35;
|
|
|
|
width: 100%;
|
|
max-width: 380px;
|
|
|
|
background-color: $secondaryColor;
|
|
font-weight: bold;
|
|
}
|
|
|
|
// Transition animations
|
|
.img-message-anim {
|
|
&-enter-from,
|
|
&-leave-to {
|
|
opacity: 0;
|
|
}
|
|
|
|
&-enter-active,
|
|
&-leave-active {
|
|
transition: opacity 75ms ease-in 100ms;
|
|
}
|
|
}
|
|
|
|
@media screen and (max-width: $breakpointMd) {
|
|
.train-image-section {
|
|
justify-content: center;
|
|
}
|
|
}
|
|
</style>
|