wf4/app/components/SkillsEasy.vue
webfussel 9a1b1acfee ADD: icons for RichTextLink
Hard coded RichTextLink icons
2025-02-21 19:52:07 +01:00

250 lines
7.7 KiB
Vue

<template>
<section id="skills_easy" class="Skills content">
<h2>Jetzt mal ganz konkret.</h2>
<h3>In diesem Abschnitt jetzt mal ganz <span class="highlight">ohne Technik-Blabla</span>.</h3>
<div class="flex-col margin-top gap-default">
<article class="z-2 card flex-row gap-default" v-for="(skill, skillIndex) in skills" :class="[skillIndex % 2 && 'reverse']">
<img :src="skill.img" alt="" class="card-img z-4" />
<div class="flex-col gap-default">
<h3>{{skill.title}}</h3>
<main class="flex-col gap-sm">
<RichText :elements="skill.text" />
</main>
</div>
</article>
</div>
<div class="bottom flex-col margin-top gap-default">
<h3>Verwirkliche jetzt dein Webprojekt.</h3>
<Button href="/contact" class="cta">
<Icon name="ph:chat-circle-text-duotone" size="1.5em" mode="svg" />
Lass mal reden
</Button>
</div>
</section>
</template>
<script setup lang="ts">
import type { RichText } from './RichText/Types'
type Skill = {
img: string
title: string
text: RichText[]
}
const skills : Skill[] = [
{
img: 'https://picsum.photos/550/350.webp?random=1',
title: 'Das, was du sehen kannst',
text: [
{
type: 'p',
children: [
{
type: 'plain',
content: 'Die meisten Anwendungen haben eine grafische Benutzeroberfläche - die so genannte GUI. Wenn etwas graphisch ist, ' +
'dann bedeutet das auch natürlich, dass es sinnvoll dargestellt werden muss. Dafür verwenden wir kleine Bausteine, die wir Komponenten nennen.',
}
]
},
{
type: 'p',
children: [
{
type: 'plain',
content: 'Grundsätzlich lassen sich komplette Anwendungen und auch einfache Webseiten ziemlich cool über Komponenten aufbauen, sodass wir wiederkehrende Elemente ' +
'wie Buttons, Textabschnitte, Links oder Teaser immer wieder verwenden können - selbst wenn sich diese in ihren Details wie Farben oder Icons unterscheiden.',
}
]
},
{
type: 'p',
children: [
{
type: 'plain',
content: 'Diese Komponenten so zu entwickeln, dass sie wirklich flexibel sind und auch perfekt mit dem Design übereinstimmen ist gar nicht so einfach, denn oft sollten sie ' +
'auch mehr können als im Design kurzfristig ersichtlich ist.',
}
]
},
{
type: 'p',
css: 'margin-top bold',
children: [
{
type: 'plain',
content: 'Diese Voraussicht, für den Fall der Fälle vorzusorgen: Die gibt\'s bei mir dazu. ',
},
{
type: 'br',
},
{
type: 'span',
css: 'highlight',
content: 'Fussel-Ehrenwort.'
}
]
},
],
}, {
img: 'https://picsum.photos/550/350.webp?random=2',
title: 'Da, wo du eintragen kannst',
text: [
{
type: 'p',
children: [
{
type: 'plain',
content: 'In vielen Fällen ist es natürlich praktisch, wenn du einfach Inhalte einer Seite auf das ändern kannst, was gerade aktuell ist, ohne auf andere angewiesen zu sein.'
+ 'Damit das reibungslos möglich ist, entwickle ich dir gerne eine Anwendung oder Homepage, deren Inhalte du komplett selbst auf dem neuesten Stand halten kannst - und zwar '
+ 'mit einem sogenannten CMS - ein ',
},
{
type: 'span',
css: 'highlight',
content: 'C'
},
{
type: 'plain',
content: 'ontent '
},
{
type: 'span',
css: 'highlight',
content: 'M'
},
{
type: 'plain',
content: 'anagement '
},
{
type: 'span',
css: 'highlight',
content: 'S'
},
{
type: 'plain',
content: 'ystem.'
},
]
},
{
type: 'p',
children: [
{
type: 'plain',
content: 'Für CMS setze ich in erster Linie auf die cloudbasierte Lösung ',
},
{
type: 'a',
target: '_blank',
css: 'text',
href: 'https://www.storyblok.com',
content: 'Storyblok'
},
{
type: 'plain',
content: '. Dies stellt für die Meisten eine kostenlose bis kostengünstige Lösung dar ohne viel technisches Wissen mitbringen zu müssen.',
}
]
},
{
type: 'p',
children: [
{
type: 'plain',
content: 'Falls du aber nicht möchtest, dass deine Daten auf irgendeinem Fremden server liegen - was ich durchaus verstehen kann! - dann gibt es auch die Möglichkeit mit ',
},
{
type: 'a',
target: '_blank',
css: 'text',
href: 'https://www.strapi.io',
content: 'Strapi'
},
{
type: 'plain',
content: ' selbst das eigene CMS zu hosten. Das musst du dann aber allerdings selbst erledigen oder ich erledige das für dich für einen Aufpreis.',
}
]
},
{
type: 'p',
css: 'margin-top bold',
children: [
{
type: 'plain',
content: 'Nie wieder jemand anderen Fragen zu müssen, um deine Website auf dem neuesten Stand zu halten.',
},
{
type: 'br',
},
{
type: 'span',
css: 'highlight',
content: 'Mit Fussel-Garantie.'
}
]
},
],
}, {
img: 'https://picsum.photos/550/350.webp?random=3',
title: 'Was dabei am Ende rauskommt',
text: [
{
type: 'p',
children: [
{
type: 'plain',
content: 'Grundsätzlich lässt sich das ganz einfach zusammenfassen: ',
},
{
type: 'span',
css: 'highlight',
content: 'Dein persönlicher Webauftritt.',
}
]
},
{
type: 'p',
children: [
{
type: 'plain',
content: 'Ob du nun etwas kleineres brauchst, um ein paar Hobbies zu zeigen. Oder vielleicht etwas größeres, weil du dir ein eigenes Business aufbauen willst. Eventuell ein eigener Blog, eine komplette Applikation oder '
+ 'die Möglichkeit für andere Leute deine Daten bereit zu stellen. All das, das kann ich dir mit meinen Fähigkeiten und meiner Erfahrung bieten.'
}
]
},
{
type: 'p',
children: [
{
type: 'plain',
content: 'Erkunde einfach meine Referenzen und dir wird auffallen, dass diese äußerst durchmischt und bunt sind. So individuell wie die Projekte meiner bisherigen Kunden wird auch dein Projekt behandelt. Und auch, wenn '
+ 'du glaubst, dass die Referenzen nicht zu deinem Projekt passen, werden wir deine ganz individuelle Lösung gemeinsam erarbeiten.'
}
]
},
{
type: 'p',
css: 'margin-top bold',
children: [
{
type: 'plain',
content: 'Denn jedes Projekt ist etwas eigenes und besonderes.',
},
{
type: 'br',
},
{
type: 'span',
css: 'highlight',
content: 'Auch deins.'
}
]
},
],
}
]
</script>