Compare commits
No commits in common. "51b66eb85b3003996ac2414757ae62ee7ba80ce5" and "0ff6df68d61404c7be7a1e9b88a354fb12ce0907" have entirely different histories.
51b66eb85b
...
0ff6df68d6
@ -1,14 +1,14 @@
|
|||||||
const config = {
|
const config = {
|
||||||
// required
|
// required
|
||||||
documentserver_key: "",
|
documentserver_key: '',
|
||||||
// required, with trailing slash
|
// required, with trailing slash
|
||||||
baseurl: "",
|
baseurl: '',
|
||||||
// optional, full url, will fallback to https://lauf-fuer-kaya.de/impressum
|
|
||||||
url_imprint: "",
|
|
||||||
// optional, full url, will fallback to https://lauf-fuer-kaya.de/datenschutz
|
|
||||||
url_privacy: "",
|
|
||||||
// full url (including fqdn)
|
// full url (including fqdn)
|
||||||
baseurl_documentserver: "http://localhost:3000",
|
baseurl_documentserver: 'http://localhost:3000',
|
||||||
// optional, will fallback to code128
|
// optional, will fallback to code128
|
||||||
code_format: "ean13",
|
code_format: 'ean13',
|
||||||
|
// optional, will fallback to /imprint
|
||||||
|
url_imprint: '',
|
||||||
|
// optional, will fallback to /privacy
|
||||||
|
url_privacy: '',
|
||||||
};
|
};
|
||||||
|
1
public/imprint_en.md
Normal file
1
public/imprint_en.md
Normal file
@ -0,0 +1 @@
|
|||||||
|
TODO:
|
1
public/privacy_en.md
Normal file
1
public/privacy_en.md
Normal file
@ -0,0 +1 @@
|
|||||||
|
TODO:
|
@ -19,8 +19,8 @@
|
|||||||
export default {
|
export default {
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
imprint_url: config.url_imprint || "https://lauf-fuer-kaya.de/impressum"
|
imprint_url: config.url_imprint || "/imprint"
|
||||||
, privacy_url: config.url_privacy || "https://lauf-fuer-kaya.de/datenschutz"
|
, privacy_url: config.url_privacy || "/privacy"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
@ -17,6 +17,8 @@
|
|||||||
"download_registrationcode": "Registrierungscode herunterladen",
|
"download_registrationcode": "Registrierungscode herunterladen",
|
||||||
"e_mail_adress": "E-Mail Adresse",
|
"e_mail_adress": "E-Mail Adresse",
|
||||||
"e_mail_des_sponsors": "E-Mail des Sponsors",
|
"e_mail_des_sponsors": "E-Mail des Sponsors",
|
||||||
|
"error-loading-privacy-policy": "Fehler beim Laden der Datenschutzerklärung",
|
||||||
|
"error_loading_imprint": "Fehler beim Laden des Impressums",
|
||||||
"error_requesting_the_login_link": "Fehler beim Anfordern des Login-Links...",
|
"error_requesting_the_login_link": "Fehler beim Anfordern des Login-Links...",
|
||||||
"first_lap": "👏 erste Runde",
|
"first_lap": "👏 erste Runde",
|
||||||
"i_accept": "Ich habe die ",
|
"i_accept": "Ich habe die ",
|
||||||
|
@ -17,6 +17,8 @@
|
|||||||
"download_registrationcode": "Download registrationcode",
|
"download_registrationcode": "Download registrationcode",
|
||||||
"e_mail_adress": "mail address",
|
"e_mail_adress": "mail address",
|
||||||
"e_mail_des_sponsors": "E-Mail of the Sponsor",
|
"e_mail_des_sponsors": "E-Mail of the Sponsor",
|
||||||
|
"error-loading-privacy-policy": "Error loading Privacy Policy",
|
||||||
|
"error_loading_imprint": "Error loading Imprint",
|
||||||
"error_requesting_the_login_link": "Error requesting the login link...",
|
"error_requesting_the_login_link": "Error requesting the login link...",
|
||||||
"first_lap": "👏 first lap",
|
"first_lap": "👏 first lap",
|
||||||
"i_accept": "I have read and accepted the ",
|
"i_accept": "I have read and accepted the ",
|
||||||
|
@ -1,13 +1,19 @@
|
|||||||
import Home from "./views/Home.vue";
|
import Home from "./views/Home.vue";
|
||||||
|
import Imprint from "./views/Imprint.vue";
|
||||||
|
import Privacy from "./views/Privacy.vue";
|
||||||
import Register from "./views/Register.vue";
|
import Register from "./views/Register.vue";
|
||||||
import Profile from "./views/Profile.vue";
|
import Profile from "./views/Profile.vue";
|
||||||
import ProfileNone from "./views/ProfileNone.vue";
|
import ProfileNone from "./views/ProfileNone.vue";
|
||||||
|
|
||||||
// console.log(config);
|
console.log(config);
|
||||||
|
|
||||||
/** @type {import('vue-router').RouterOptions['routes']} */
|
/** @type {import('vue-router').RouterOptions['routes']} */
|
||||||
export const routes = [
|
export const routes = [
|
||||||
{ path: "/", component: Home },
|
{ path: "/", component: Home },
|
||||||
|
{ path: "/imprint", component: Imprint },
|
||||||
|
{ path: "/imprint/", component: Imprint },
|
||||||
|
{ path: "/privacy", component: Privacy },
|
||||||
|
{ path: "/privacy/", component: Privacy },
|
||||||
{ path: "/register", component: Register },
|
{ path: "/register", component: Register },
|
||||||
{ path: "/register/", component: Register },
|
{ path: "/register/", component: Register },
|
||||||
{ path: "/register/:token", component: Register, props: true },
|
{ path: "/register/:token", component: Register, props: true },
|
||||||
|
@ -5,9 +5,9 @@
|
|||||||
<div class="w-full mx-auto text-center">
|
<div class="w-full mx-auto text-center">
|
||||||
<img src="/favicon-lfk.png" class="h-32 mx-auto" />
|
<img src="/favicon-lfk.png" class="h-32 mx-auto" />
|
||||||
<h1
|
<h1
|
||||||
class="mb-6 text-4xl font-extrabold leading-none tracking-normal md:text-6xl md:tracking-tight">
|
class="mb-6 text-4xl font-extrabold leading-none tracking-normal md:text-6xl md:tracking-tight font-[Athiti]">
|
||||||
Lauf Für Kaya!<br>2025</h1>
|
Lauf Für Kaya!<br>2025</h1>
|
||||||
<h2 class="mb-6 text-xl font-bold leading-none tracking-normal md:text-3xl md:tracking-tight">
|
<h2 class="mb-6 text-xl font-bold leading-none tracking-normal md:text-3xl md:tracking-tight font-[Athiti]">
|
||||||
Selfservice Portal</h2>
|
Selfservice Portal</h2>
|
||||||
<p class="px-0 mb-6 text-md lg:px-24 font-medium">{{ $t('main_page_text') }}</p>
|
<p class="px-0 mb-6 text-md lg:px-24 font-medium">{{ $t('main_page_text') }}</p>
|
||||||
<a class="w-full block mx-auto md:w-3/4 px-6 py-3 border border-transparent text-base font-semibold rounded-md text-gray-900 bg-white shadow-sm hover:text-gray-600 focus:outline-none focus:text-gray-600 xl:text-lg xl:py-4"
|
<a class="w-full block mx-auto md:w-3/4 px-6 py-3 border border-transparent text-base font-semibold rounded-md text-gray-900 bg-white shadow-sm hover:text-gray-600 focus:outline-none focus:text-gray-600 xl:text-lg xl:py-4"
|
||||||
|
40
src/views/Imprint.vue
Normal file
40
src/views/Imprint.vue
Normal file
@ -0,0 +1,40 @@
|
|||||||
|
<template>
|
||||||
|
<section class="px-4 py-24 mx-auto">
|
||||||
|
<div class="simplecontent">
|
||||||
|
<div class="mb-24 text-left md:text-center">
|
||||||
|
<h1 class="mb-4 text-4xl font-bold leading-tight text-gray-900 dark:text-gray-50 md:text-5xl">{{ $t('imprint')
|
||||||
|
}}
|
||||||
|
</h1>
|
||||||
|
</div>
|
||||||
|
<div class="mx-auto prose" v-html="content"></div>
|
||||||
|
</div>
|
||||||
|
</section>
|
||||||
|
<Footer></Footer>
|
||||||
|
</template>
|
||||||
|
<style src="../simple.css"></style>
|
||||||
|
<script>
|
||||||
|
import { marked } from "marked";
|
||||||
|
import Footer from "@/components/Footer.vue";
|
||||||
|
export default {
|
||||||
|
components: { Footer },
|
||||||
|
data() {
|
||||||
|
return {
|
||||||
|
content: "",
|
||||||
|
}
|
||||||
|
},
|
||||||
|
async beforeMount() {
|
||||||
|
const browserlocale = ((navigator.languages && navigator.languages[0]) || '').substr(0, 2);
|
||||||
|
let md = "";
|
||||||
|
try {
|
||||||
|
md = await fetch(`/imprint_${browserlocale}.md`);
|
||||||
|
} catch (error) {
|
||||||
|
try {
|
||||||
|
md = await fetch(`/imprint_en.md`);
|
||||||
|
} catch (error) {
|
||||||
|
md = t('error_loading_imprint');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
this.content = marked(await md.text());
|
||||||
|
},
|
||||||
|
}
|
||||||
|
</script>
|
39
src/views/Privacy.vue
Normal file
39
src/views/Privacy.vue
Normal file
@ -0,0 +1,39 @@
|
|||||||
|
<template>
|
||||||
|
<section class="px-4 py-24 mx-auto">
|
||||||
|
<div class="simplecontent">
|
||||||
|
<div class="mb-24 text-left md:text-center">
|
||||||
|
<h1 class="mb-4 text-4xl font-bold leading-tight text-gray-900 dark:text-gray-50 md:text-5xl">{{
|
||||||
|
$t('privacy_policy') }}</h1>
|
||||||
|
</div>
|
||||||
|
<div class="mx-auto prose" v-html="content"></div>
|
||||||
|
</div>
|
||||||
|
</section>
|
||||||
|
<Footer></Footer>
|
||||||
|
</template>
|
||||||
|
<style src="../simple.css"></style>
|
||||||
|
<script>
|
||||||
|
import { marked } from "marked";
|
||||||
|
import Footer from "@/components/Footer.vue";
|
||||||
|
export default {
|
||||||
|
components: { Footer },
|
||||||
|
data() {
|
||||||
|
return {
|
||||||
|
content: ""
|
||||||
|
}
|
||||||
|
},
|
||||||
|
async beforeMount() {
|
||||||
|
const browserlocale = ((navigator.languages && navigator.languages[0]) || '').substr(0, 2);
|
||||||
|
let md = "";
|
||||||
|
try {
|
||||||
|
md = await fetch(`/privacy_${browserlocale}.md`);
|
||||||
|
} catch (error) {
|
||||||
|
try {
|
||||||
|
md = await fetch(`/privacy_en.md`);
|
||||||
|
} catch (error) {
|
||||||
|
md = t('error-loading-privacy-policy');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
this.content = marked(await md.text());
|
||||||
|
},
|
||||||
|
}
|
||||||
|
</script>
|
@ -4,7 +4,7 @@
|
|||||||
<div class="md:pr-10 md:mb-0 mb-6 pr-0 w-full text-center text-black dark:text-gray-200">
|
<div class="md:pr-10 md:mb-0 mb-6 pr-0 w-full text-center text-black dark:text-gray-200">
|
||||||
<img src="/favicon-lfk.png" class="h-20 mx-auto" />
|
<img src="/favicon-lfk.png" class="h-20 mx-auto" />
|
||||||
<div v-if="loadstate === 'loaded'">
|
<div v-if="loadstate === 'loaded'">
|
||||||
<h1 class="text-3xl font-bold whitespace-nowrap" v-text="(state.firstname || '') +
|
<h1 class="text-3xl font-bold whitespace-nowrap font-[Athiti]" v-text="(state.firstname || '') +
|
||||||
' ' +
|
' ' +
|
||||||
(state.middlename || '') +
|
(state.middlename || '') +
|
||||||
' ' +
|
' ' +
|
||||||
@ -12,55 +12,69 @@
|
|||||||
"></h1>
|
"></h1>
|
||||||
<p class="text-md whitespace-nowrap">Team: {{ state.group }}</p>
|
<p class="text-md whitespace-nowrap">Team: {{ state.group }}</p>
|
||||||
</div>
|
</div>
|
||||||
<h1 v-else class="text-3xl font-bold whitespace-nowrap">Daten werden geladen...</h1>
|
<h1 v-else class="text-3xl font-bold whitespace-nowrap font-[Athiti]">Daten werden geladen...</h1>
|
||||||
</div>
|
</div>
|
||||||
<div v-if="loadstate === 'loaded'" class="flex flex-wrap">
|
<div v-if="loadstate === 'loaded'" class="flex flex-wrap">
|
||||||
<div class="w-full">
|
<div class="w-full">
|
||||||
<div class="flex flex-wrap flex-col w-full tabs">
|
<div class="flex flex-wrap flex-col w-full tabs">
|
||||||
<div class="grid grid-cols-3 text-center gap-1">
|
<div class="flex lg:flex-wrap flex-row lg:space-x-2 justify-center">
|
||||||
|
<div class="flex-none">
|
||||||
<button @click="() => {
|
<button @click="() => {
|
||||||
state.activetab = 'profile';
|
state.activetab = 'profile';
|
||||||
}
|
}
|
||||||
" :class="{
|
" :class="{
|
||||||
'tab-active font-medium bg-blue-600 hover:bg-blue-700 text-white':
|
'tab-active border-b-2 font-medium border-blue-500':
|
||||||
state.activetab === 'profile',
|
state.activetab === 'profile',
|
||||||
'bg-neutral-200':
|
}" class="tab tab-underline cursor-pointer py-4 px-6 block" type="button">
|
||||||
state.activetab !== 'profile',
|
|
||||||
}" class="cursor-pointer rounded-md p-2 py-3 md:py-4 md:px-6 block" type="button">
|
|
||||||
{{ $t("profile") }}
|
{{ $t("profile") }}
|
||||||
</button>
|
</button>
|
||||||
|
</div>
|
||||||
|
<div class="flex-none">
|
||||||
<button @click="() => {
|
<button @click="() => {
|
||||||
state.activetab = 'laptimes';
|
state.activetab = 'laptimes';
|
||||||
}
|
}
|
||||||
" :class="{
|
" :class="{
|
||||||
'tab-active font-medium bg-blue-600 hover:bg-blue-700 text-white':
|
'tab-active border-b-2 font-medium border-blue-500':
|
||||||
state.activetab === 'laptimes',
|
state.activetab === 'laptimes',
|
||||||
'bg-neutral-200':
|
}" class="tab tab-underline cursor-pointer py-4 px-6 block" type="button">
|
||||||
state.activetab !== 'laptimes',
|
|
||||||
}" class="cursor-pointer rounded-md p-2 py-3 md:py-4 md:px-6 block" type="button">
|
|
||||||
{{ $t("lap_times") }}
|
{{ $t("lap_times") }}
|
||||||
</button>
|
</button>
|
||||||
|
</div>
|
||||||
|
<div class="flex-none">
|
||||||
<button @click="() => {
|
<button @click="() => {
|
||||||
state.activetab = 'sponsorings';
|
state.activetab = 'sponsorings';
|
||||||
}
|
}
|
||||||
" :class="{
|
" :class="{
|
||||||
'tab-active font-medium bg-blue-600 hover:bg-blue-700 text-white':
|
'tab-active border-b-2 font-medium border-blue-500':
|
||||||
state.activetab === 'sponsorings',
|
state.activetab === 'sponsorings',
|
||||||
'bg-neutral-200':
|
}" class="tab tab-underline cursor-pointer py-4 px-6 block" type="button">
|
||||||
state.activetab !== 'sponsorings',
|
|
||||||
}" class="cursor-pointer rounded-md p-2 py-3 md:py-4 md:px-6 block" type="button">
|
|
||||||
{{ $t("sponsoring") }}
|
{{ $t("sponsoring") }}
|
||||||
</button>
|
</button>
|
||||||
</div>
|
</div>
|
||||||
|
</div>
|
||||||
<div v-if="state.activetab === 'profile'" class="tab-content block">
|
<div v-if="state.activetab === 'profile'" class="tab-content block">
|
||||||
<div class="w-full mx-auto">
|
<div class="w-full mx-auto">
|
||||||
<div class="flex flex-col">
|
<div class="flex flex-col">
|
||||||
<div class="flex flex-wrap w-full">
|
<div class="flex flex-wrap w-full">
|
||||||
<div class="w-full">
|
<div class="w-full">
|
||||||
<div v-if="state.delete_active === false">
|
<div v-if="state.delete_active === false">
|
||||||
<button type="button"
|
<button type="button" class="
|
||||||
class="mt-2 focus:border-black focus:ring-2 focus:ring-black text-white text-base md:text-sm py-3.5 px-5 md:py-2.5 md:px-5 rounded-md bg-blue-600 hover:bg-blue-700 hover:shadow-lg w-full md:w-auto cursor-pointer mb-1 md:mr-1"
|
mt-2
|
||||||
@click="get_certificate">
|
focus:border-black focus:ring-2 focus:ring-black
|
||||||
|
text-white text-base md:text-sm
|
||||||
|
py-3.5
|
||||||
|
px-5
|
||||||
|
md:py-2.5
|
||||||
|
md:px-5
|
||||||
|
rounded-md
|
||||||
|
bg-blue-500
|
||||||
|
hover:bg-blue-600 hover:shadow-lg
|
||||||
|
w-full
|
||||||
|
md:w-auto
|
||||||
|
cursor-pointer
|
||||||
|
mb-1
|
||||||
|
md:mr-1
|
||||||
|
" @click="get_certificate">
|
||||||
<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none"
|
<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none"
|
||||||
stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"
|
stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"
|
||||||
class="inline h-4 align-sub">
|
class="inline h-4 align-sub">
|
||||||
@ -75,9 +89,22 @@
|
|||||||
<div>
|
<div>
|
||||||
<div class="text-lg">{{ $t("registrationcode") }}</div>
|
<div class="text-lg">{{ $t("registrationcode") }}</div>
|
||||||
<img class="w-full md:w-auto mb-2 bg-white p-2" alt="Registrierungscode" :src="state.barcode" />
|
<img class="w-full md:w-auto mb-2 bg-white p-2" alt="Registrierungscode" :src="state.barcode" />
|
||||||
<button type="button"
|
<button type="button" class="
|
||||||
class="focus:border-black focus:ring-2 focus:ring-black text-white text-base md:text-sm py-3.5 px-5 md:py-2.5 md:px-5 rounded-md bg-blue-600 hover:bg-blue-700 hover:shadow-lg w-full md:w-auto cursor-pointer mb-1 md:mr-1"
|
focus:border-black focus:ring-2 focus:ring-black
|
||||||
@click="get_registration">
|
text-white text-base md:text-sm
|
||||||
|
py-3.5
|
||||||
|
px-5
|
||||||
|
md:py-2.5
|
||||||
|
md:px-5
|
||||||
|
rounded-md
|
||||||
|
bg-blue-500
|
||||||
|
hover:bg-blue-600 hover:shadow-lg
|
||||||
|
w-full
|
||||||
|
md:w-auto
|
||||||
|
cursor-pointer
|
||||||
|
mb-1
|
||||||
|
md:mr-1
|
||||||
|
" @click="get_registration">
|
||||||
<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none"
|
<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none"
|
||||||
stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"
|
stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"
|
||||||
class="inline h-4 align-sub">
|
class="inline h-4 align-sub">
|
||||||
@ -100,9 +127,22 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div v-if="state.delete_active === true">
|
<div v-if="state.delete_active === true">
|
||||||
<button type="button"
|
<button type="button" class="
|
||||||
class="focus:border-black focus:ring-2 focus:ring-black text-white text-base md:text-sm py-3.5 px-5 md:py-2.5 md:px-5 rounded-md mb-1 md:mb-auto w-full md:w-auto cursor-pointer bg-blue-600 hover:bg-blue-700 hover:shadow-lg"
|
focus:border-black focus:ring-2 focus:ring-black
|
||||||
@click="() => {
|
text-white text-base md:text-sm
|
||||||
|
py-3.5
|
||||||
|
px-5
|
||||||
|
md:py-2.5
|
||||||
|
md:px-5
|
||||||
|
rounded-md
|
||||||
|
mb-1
|
||||||
|
md:mb-auto
|
||||||
|
w-full
|
||||||
|
md:w-auto
|
||||||
|
cursor-pointer
|
||||||
|
bg-blue-500
|
||||||
|
hover:bg-blue-600 hover:shadow-lg
|
||||||
|
" @click="() => {
|
||||||
state.delete_active = false;
|
state.delete_active = false;
|
||||||
}
|
}
|
||||||
">
|
">
|
||||||
@ -114,9 +154,21 @@
|
|||||||
</svg>
|
</svg>
|
||||||
{{ $t("cancel_keep_my_data") }}
|
{{ $t("cancel_keep_my_data") }}
|
||||||
</button>
|
</button>
|
||||||
<button type="button"
|
<button type="button" class="
|
||||||
class="focus:border-black focus:ring-2 focus:ring-black text-white text-base md:text-sm py-3.5 px-5 md:py-2.5 md:px-5 rounded-md w-full md:w-auto cursor-pointer bg-red-600 hover:bg-red-700 hover:shadow-lg md:ml-1"
|
focus:border-black focus:ring-2 focus:ring-black
|
||||||
@click="delete_me">
|
text-white text-base md:text-sm
|
||||||
|
py-3.5
|
||||||
|
px-5
|
||||||
|
md:py-2.5
|
||||||
|
md:px-5
|
||||||
|
rounded-md
|
||||||
|
w-full
|
||||||
|
md:w-auto
|
||||||
|
cursor-pointer
|
||||||
|
bg-red-600
|
||||||
|
hover:bg-red-700 hover:shadow-lg
|
||||||
|
md:ml-1
|
||||||
|
" @click="delete_me">
|
||||||
<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none"
|
<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none"
|
||||||
stroke="none" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"
|
stroke="none" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"
|
||||||
class="inline h-4 align-sub">
|
class="inline h-4 align-sub">
|
||||||
@ -127,9 +179,20 @@
|
|||||||
{{ $t("confirm_delete_all_of_my_data") }}
|
{{ $t("confirm_delete_all_of_my_data") }}
|
||||||
</button>
|
</button>
|
||||||
</div>
|
</div>
|
||||||
<button v-else type="button"
|
<button v-else type="button" class="
|
||||||
class="focus:border-black focus:ring-2 focus:ring-black text-white text-base md:text-sm py-3.5 px-5 md:py-2.5 md:px-5 rounded-md bg-red-600 hover:bg-red-700 hover:shadow-lg w-full md:w-auto cursor-pointer"
|
focus:border-black focus:ring-2 focus:ring-black
|
||||||
@click="() => {
|
text-white text-base md:text-sm
|
||||||
|
py-3.5
|
||||||
|
px-5
|
||||||
|
md:py-2.5
|
||||||
|
md:px-5
|
||||||
|
rounded-md
|
||||||
|
bg-red-600
|
||||||
|
hover:bg-red-700 hover:shadow-lg
|
||||||
|
w-full
|
||||||
|
md:w-auto
|
||||||
|
cursor-pointer
|
||||||
|
" @click="() => {
|
||||||
state.delete_active = true;
|
state.delete_active = true;
|
||||||
}
|
}
|
||||||
">
|
">
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
<div class="min-h-screen flex items-center justify-center">
|
<div class="min-h-screen flex items-center justify-center">
|
||||||
<div class="max-w-md w-full py-12 px-6">
|
<div class="max-w-md w-full py-12 px-6">
|
||||||
<img class="mx-auto h-24 w-auto" src="/favicon-lfk.png" alt />
|
<img class="mx-auto h-24 w-auto" src="/favicon-lfk.png" alt />
|
||||||
<h1 class="sm:text-3xl text-2xl font-semibold title-font mb-4 text-center">Lauf für Kaya! - {{
|
<h1 class="sm:text-3xl text-2xl font-semibold title-font mb-4 text-center font-[Athiti]">Lauf für Kaya! - {{
|
||||||
$t('profile')
|
$t('profile')
|
||||||
}}</h1>
|
}}</h1>
|
||||||
<p class="mx-auto leading-relaxed text-base text-center">
|
<p class="mx-auto leading-relaxed text-base text-center">
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
<template>
|
<template>
|
||||||
<div class="min-h-screen flex items-center justify-center" v-if="registrationState === 'registered'">
|
<div class="min-h-screen flex items-center justify-center" v-if="registrationState === 'registered'">
|
||||||
<div class="max-w-md w-full py-12 px-6">
|
<div class="max-w-md w-full py-12 px-6 font-[Athiti]">
|
||||||
<img class="mx-auto h-24 w-auto" src="/favicon-lfk.png" alt />
|
<img class="mx-auto h-24 w-auto" src="/favicon-lfk.png" alt />
|
||||||
<h1 class="sm:text-3xl text-2xl font-semibold title-font mb-4 text-center">
|
<h1 class="sm:text-3xl text-2xl font-semibold title-font mb-4 text-center">
|
||||||
Lauf für Kaya! - {{ $t('registriert') }}
|
Lauf für Kaya! - {{ $t('registriert') }}
|
||||||
@ -12,7 +12,7 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="min-h-screen flex items-center justify-center" v-else>
|
<div class="min-h-screen flex items-center justify-center" v-else>
|
||||||
<div class="max-w-md w-full py-12 px-6">
|
<div class="max-w-md w-full py-12 px-6 font-[Athiti]">
|
||||||
<img class="mx-auto h-24 w-auto" src="/favicon-lfk.png" alt />
|
<img class="mx-auto h-24 w-auto" src="/favicon-lfk.png" alt />
|
||||||
<h1 class="sm:text-3xl text-2xl font-semibold title-font mb-4 text-center">
|
<h1 class="sm:text-3xl text-2xl font-semibold title-font mb-4 text-center">
|
||||||
Lauf für Kaya! - {{ $t("registrieren") }}
|
Lauf für Kaya! - {{ $t("registrieren") }}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user