added onride embed and fixed some design errors
This commit is contained in:
@@ -28,55 +28,64 @@ export default {
|
||||
|
||||
<template>
|
||||
<title>{{ coaster.name }} - CoasterDB</title>
|
||||
|
||||
<!-- Fester Header -->
|
||||
<Header />
|
||||
<div style="margin-top: 63px;">
|
||||
<section class="bg-gray-50 dark:bg-gray-900 p-3 sm:p-5">
|
||||
<div class="mx-auto max-w-screen-xl px-4 lg:px-12">
|
||||
<div class="bg-white dark:bg-gray-800 relative shadow-md sm:rounded-lg overflow-hidden">
|
||||
<div class="p-6">
|
||||
<h1 class="text-2xl font-bold text-gray-900 dark:text-white mb-4">{{ coaster.name }}</h1>
|
||||
<p class="text-sm text-gray-500 dark:text-gray-400 mb-6">Park: <span class="font-medium text-gray-900 dark:text-white"><a :href="`/app/park/${coaster.park.replace(' ', '_')}`">{{ coaster.park }}</a></span></p>
|
||||
<div class="grid grid-cols-1 md:grid-cols-2 gap-6">
|
||||
<div class="bg-gray-100 dark:bg-gray-700 p-4 rounded-lg shadow-sm">
|
||||
<p class="text-gray-600 dark:text-gray-300">Streckenlänge:</p>
|
||||
<p class="text-lg font-semibold text-gray-900 dark:text-white">{{ coaster.length }}</p>
|
||||
</div>
|
||||
<div class="bg-gray-100 dark:bg-gray-700 p-4 rounded-lg shadow-sm">
|
||||
<p class="text-gray-600 dark:text-gray-300">Maximale Höhe:</p>
|
||||
<p class="text-lg font-semibold text-gray-900 dark:text-white">{{ coaster.height }}</p>
|
||||
</div>
|
||||
<div class="bg-gray-100 dark:bg-gray-700 p-4 rounded-lg shadow-sm">
|
||||
<p class="text-gray-600 dark:text-gray-300">Maximale Geschwindigkeit:</p>
|
||||
<p class="text-lg font-semibold text-gray-900 dark:text-white">{{ coaster.speed }}</p>
|
||||
</div>
|
||||
<div class="bg-gray-100 dark:bg-gray-700 p-4 rounded-lg shadow-sm">
|
||||
<p class="text-gray-600 dark:text-gray-300">Launch-System:</p>
|
||||
<p class="text-lg font-semibold text-gray-900 dark:text-white">{{ coaster.launch }}</p>
|
||||
</div>
|
||||
<div class="bg-gray-100 dark:bg-gray-700 p-4 rounded-lg shadow-sm">
|
||||
<p class="text-gray-600 dark:text-gray-300">Anzahl Inversionen:</p>
|
||||
<p class="text-lg font-semibold text-gray-900 dark:text-white">{{ coaster.inversions }}</p>
|
||||
</div>
|
||||
<div class="bg-gray-100 dark:bg-gray-700 p-4 rounded-lg shadow-sm">
|
||||
<p class="text-gray-600 dark:text-gray-300">Fahrtdauer:</p>
|
||||
<p class="text-lg font-semibold text-gray-900 dark:text-white">{{ coaster.duration }}</p>
|
||||
</div>
|
||||
<div class="bg-gray-100 dark:bg-gray-700 p-4 rounded-lg shadow-sm">
|
||||
<p class="text-gray-600 dark:text-gray-300">Hersteller:</p>
|
||||
<p class="text-lg font-semibold text-gray-900 dark:text-white">{{ coaster.manufacturer }}</p>
|
||||
</div>
|
||||
<div class="bg-gray-100 dark:bg-gray-700 p-4 rounded-lg shadow-sm">
|
||||
<p class="text-gray-600 dark:text-gray-300">Eröffnet:</p>
|
||||
<p class="text-lg font-semibold text-gray-900 dark:text-white">{{ coaster.opened }}</p>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<!-- Flex-Layout für Sidebar + Inhalt -->
|
||||
<div class="flex pt-[63px] h-screen overflow-hidden">
|
||||
<!-- Sidebar -->
|
||||
<Sidebar />
|
||||
|
||||
<!-- Hauptinhalt -->
|
||||
<main class="flex-1 overflow-y-auto p-5 bg-gray-50 dark:bg-gray-900">
|
||||
<div style="margin-top: 63px;"></div>
|
||||
<div class="mx-auto max-w-screen-xl px-4 lg:px-12">
|
||||
<div class="bg-white dark:bg-gray-800 relative shadow-md sm:rounded-lg overflow-hidden">
|
||||
<div class="p-6">
|
||||
<h1 class="text-2xl font-bold text-gray-900 dark:text-white mb-4">{{ coaster.name }}</h1>
|
||||
<p class="text-sm text-gray-500 dark:text-gray-400 mb-6">
|
||||
Park:
|
||||
<span class="font-medium text-gray-900 dark:text-white">
|
||||
<a :href="`/app/park/${coaster.park.replace(' ', '_')}`">{{ coaster.park }}</a>
|
||||
</span>
|
||||
</p>
|
||||
<div class="grid grid-cols-1 md:grid-cols-2 gap-6">
|
||||
<div v-for="(value, label) in {
|
||||
'Streckenlänge': coaster.length,
|
||||
'Maximale Höhe': coaster.height,
|
||||
'Maximale Geschwindigkeit': coaster.speed,
|
||||
'Launch-System': coaster.launch,
|
||||
'Anzahl Inversionen': coaster.inversions,
|
||||
'Fahrtdauer': coaster.duration,
|
||||
'Hersteller': coaster.manufacturer,
|
||||
'Eröffnet': coaster.opened
|
||||
}"
|
||||
:key="label"
|
||||
class="bg-gray-100 dark:bg-gray-700 p-4 rounded-lg shadow-sm"
|
||||
>
|
||||
<p class="text-gray-600 dark:text-gray-300">{{ label }}:</p>
|
||||
<p class="text-lg font-semibold text-gray-900 dark:text-white">{{ value }}</p>
|
||||
</div>
|
||||
</div>
|
||||
<!-- Embedded YouTube Video -->
|
||||
<div class="mt-6">
|
||||
<h2 class="text-xl font-bold text-gray-900 dark:text-white mb-4">On-Ride Video</h2>
|
||||
<div class="aspect-w-16 aspect-h-9">
|
||||
<iframe
|
||||
width="560"
|
||||
height="315"
|
||||
src="https://www.youtube.com/embed/P7m8SNRj_hI"
|
||||
title="Blue Fire On-Ride Video"
|
||||
frameborder="0"
|
||||
allow="accelerometer; autoplay; encrypted-media; gyroscope; picture-in-picture"
|
||||
allowfullscreen
|
||||
></iframe>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</section>
|
||||
</div>
|
||||
</div>
|
||||
</main>
|
||||
</div>
|
||||
<Sidebar />
|
||||
</template>
|
||||
|
||||
<style scoped>
|
||||
</style>
|
||||
</template>
|
||||
Reference in New Issue
Block a user