light mode and a few improvements
This commit is contained in:
60
pages/blog/[...slug].vue
Normal file → Executable file
60
pages/blog/[...slug].vue
Normal file → Executable file
@@ -1,42 +1,46 @@
|
||||
<script setup lang="ts">
|
||||
let year = new Date().getFullYear();
|
||||
</script>
|
||||
|
||||
<template>
|
||||
<Nav />
|
||||
<div class="grid grid-cols-12 gap-5 justify-center">
|
||||
<div class="pt-6 mb-4 !col-start-2 md:!col-start-3 lg:!col-start-4 lg:col-span-6 md:col-span-8 col-span-10">
|
||||
<ContentDoc v-slot="{ doc }">
|
||||
<img :src="doc.image.src"
|
||||
class="mb-2 rounded-md drop-shadow" />
|
||||
<h1 class="text-3xl text-gray-100 md:text-4xl font-semibold mb-2">{{ doc.title }}</h1>
|
||||
<p class="mb-1 text-zinc-400">
|
||||
{{ doc.description }}
|
||||
</p>
|
||||
<p class="mb-2 text-zinc-500">
|
||||
{{ new Date(doc.date).toDateString().split(' ').slice(1).join(' ') }}
|
||||
</p>
|
||||
<div class="flex flex-wrap w-full gap-2 justify-start mb-3">
|
||||
<IconTag v-for="tag in doc.tags"
|
||||
:name="tag"
|
||||
:iconName='tag'
|
||||
isTag="true" />
|
||||
</div>
|
||||
<main id="main">
|
||||
<ContentRenderer
|
||||
class="text-gray-200"
|
||||
:value="doc" />
|
||||
</main>
|
||||
</ContentDoc>
|
||||
<div class="min-h-screen">
|
||||
<Nav />
|
||||
<div class="grid grid-cols-12 gap-5 justify-center">
|
||||
<div class="pt-6 mb-4 !col-start-2 md:!col-start-3 lg:!col-start-4 lg:col-span-6 md:col-span-8 col-span-10">
|
||||
<ContentDoc v-slot="{ doc }">
|
||||
<img :src="doc.image.src" class="mb-2 rounded-md drop-shadow" />
|
||||
<h1 class="text-3xl dark:text-gray-100 md:text-4xl font-semibold mb-2">{{ doc.title }}</h1>
|
||||
<p class="mb-1 dark:text-zinc-400 text-zinc-600">
|
||||
{{ doc.description }}
|
||||
</p>
|
||||
<p class="mb-2 text-zinc-500">
|
||||
{{ new Date(doc.date).toDateString().split(' ').slice(1).join(' ') }}
|
||||
</p>
|
||||
<div class="flex flex-wrap w-full gap-2 justify-start mb-3">
|
||||
<IconTag v-for="tag in doc.tags" :name="tag" :iconName='tag' isTag="true" />
|
||||
</div>
|
||||
<main id="main" class="leading-relaxed">
|
||||
<ContentRenderer class="dark:text-gray-200 text-gray-800" :value="doc" />
|
||||
</main>
|
||||
</ContentDoc>
|
||||
</div>
|
||||
</div>
|
||||
<footer class="grid grid-cols-12 gap-5 justify-center">
|
||||
<div class="py-2 mb-4 !col-start-3 md:!col-start-4 xl:!col-start-5 xl:col-span-4 md:col-span-6 col-span-8">
|
||||
<!-- <NewsletterSignup class="mb-2" /> -->
|
||||
© 2022 Juls07 - GPL v3.0 License
|
||||
© {{ year }} Juls07 - GPL v3.0 License
|
||||
</div>
|
||||
</footer>
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<style>
|
||||
br {
|
||||
@apply my-3;
|
||||
display: block;
|
||||
@apply my-3;
|
||||
display: block;
|
||||
}
|
||||
|
||||
#main a {
|
||||
@apply text-fuschia hover:underline visited:bg-rose-700;
|
||||
}
|
||||
</style>
|
||||
|
||||
94
pages/blog/index.vue
Normal file → Executable file
94
pages/blog/index.vue
Normal file → Executable file
@@ -1,52 +1,48 @@
|
||||
<template>
|
||||
<div class="h-screen text-white">
|
||||
<div class="min-h-screen">
|
||||
<Nav />
|
||||
<main>
|
||||
<div id="main"
|
||||
class="gap-4 justify-evenly py-2 grid grid-cols-[repeat(auto-fit,_minmax(50px,_450px))]">
|
||||
<div v-for="article in articles"
|
||||
:key="article._path"
|
||||
class="mb-5 px-1.5">
|
||||
<div
|
||||
class="text-white bg-[#201F20] max-h-[563.25px] h-[563.25px] overflow-hidden rounded-lg border border-zinc-700/30 shadow-md">
|
||||
<img v-if="article.image.src"
|
||||
:src="article.image.src"
|
||||
class="w-full rounded-tl-lg rounded-tr-lg aspect-video" />
|
||||
<div id="main" class="gap-4 justify-evenly py-2 grid grid-cols-[repeat(auto-fit,_minmax(50px,_450px))]">
|
||||
<ContentQuery path="blog" :only="['image', '_path', 'title', 'description', 'date', 'tags', 'excerpt']"
|
||||
:sort="{
|
||||
date: -1
|
||||
}" :where="{
|
||||
_draft: false
|
||||
}" v-slot="{ data }">
|
||||
<div v-for="article in data" :key="article._path" class="mb-5 px-1.5">
|
||||
<div
|
||||
class="p-3 overflow-hidden pt-2 text-fade mb-1 pb-1 relative">
|
||||
<h3>
|
||||
<nuxt-link tabindex="0"
|
||||
class="text-lg"
|
||||
:to="article._path">
|
||||
{{ article.title }}
|
||||
</nuxt-link>
|
||||
</h3>
|
||||
<p class="text-zinc-400">
|
||||
{{ article.description }}
|
||||
</p>
|
||||
<p class="text-zinc-500">
|
||||
{{ new Date(article.date).toDateString().split(' ').slice(1).join(' ') }}
|
||||
</p>
|
||||
<p class="text-zinc-200 max-h-[13.75rem]">
|
||||
<ContentDoc :head="false"
|
||||
:value="article"
|
||||
:path="article._path"
|
||||
v-slot="{ doc }">
|
||||
<div class="flex flex-wrap w-full gap-2 justify-start my-1">
|
||||
<IconTag v-for="tag in doc.tags"
|
||||
:name="tag"
|
||||
:iconName='tag'
|
||||
isTag="true" />
|
||||
</div>
|
||||
<div class="max-h-full">
|
||||
<ContentRenderer :value="doc"
|
||||
:excerpt="true" />
|
||||
</div>
|
||||
</ContentDoc>
|
||||
</p>
|
||||
class="dark:bg-dark-slate bg-touched-lavender max-h-[563.25px] h-[563.25px] overflow-hidden rounded-lg border border-soft-lilac dark:border-midnight-slate/30 shadow-md">
|
||||
<NuxtImg v-if="article.image.src" :src="article.image.src"
|
||||
class="w-full rounded-tl-lg rounded-tr-lg aspect-video" loading="lazy" />
|
||||
<div
|
||||
class="p-3 overflow-hidden pt-2 text-fade dark:before:bg-[linear-gradient(180deg,transparent_0,hsla(0,0%,5%,0)_36%,#0C0B0C_95%,#0C0B0C)] before:bg-[linear-gradient(180deg,transparent_0,hsla(0,0%,5%,0)_36%,#F5EDFE_95%,#F5EDFE)] mb-1 pb-1 relative">
|
||||
<h3>
|
||||
<nuxt-link tabindex="0" class="text-lg" :to="article._path">
|
||||
{{ article.title }}
|
||||
</nuxt-link>
|
||||
</h3>
|
||||
<p class="dark:text-zinc-400 text-zinc-600">
|
||||
{{ article.description }}
|
||||
</p>
|
||||
<p class="text-zinc-500">
|
||||
{{ new Date(article.date).toDateString().split(' ').slice(1).join(' ') }}
|
||||
</p>
|
||||
<p class="dark:text-zinc-200 text-zinc-800 max-h-[13.75rem]">
|
||||
<ContentDoc :head="false" :value="article" :path="article._path" v-slot="{ doc }">
|
||||
<div class="flex flex-wrap w-full gap-2 justify-start my-1">
|
||||
<IconTag v-for="tag in doc.tags" :name="tag" :iconName='tag' isTag="true" />
|
||||
</div>
|
||||
<div class="max-h-full leading-relaxed">
|
||||
<ContentRenderer :value="doc">
|
||||
<ContentRendererMarkdown :value="doc" :excerpt="true" />
|
||||
</ContentRenderer>
|
||||
</div>
|
||||
</ContentDoc>
|
||||
</p>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</ContentQuery>
|
||||
</div>
|
||||
</main>
|
||||
</div>
|
||||
@@ -60,18 +56,14 @@
|
||||
height: 33.333333%;
|
||||
left: 0px;
|
||||
bottom: 0px;
|
||||
background-image: linear-gradient(to bottom, rgba(0,0,0,0) 0%, rgba(12,12,12,0) 36%, rgba(32,31,32,1) 95%, rgba(32,31,32,1) 100%);
|
||||
}
|
||||
|
||||
#main a {
|
||||
@apply text-fuschia hover:underline visited:bg-rose-700;
|
||||
}
|
||||
</style>
|
||||
|
||||
<script setup lang="ts">
|
||||
const { data: articles } = await useAsyncData('posts-list', () => queryContent('/blog')
|
||||
.only(['image', '_path', 'title', 'description', 'date'])
|
||||
.where({ _draft: false })
|
||||
.sort({ date: -1, $numeric: true, })
|
||||
.find()
|
||||
);
|
||||
|
||||
useHead({
|
||||
title: 'Juls07',
|
||||
})
|
||||
|
||||
309
pages/index.vue
Normal file → Executable file
309
pages/index.vue
Normal file → Executable file
@@ -1,164 +1,11 @@
|
||||
<template>
|
||||
<div class="h-screen text-white">
|
||||
<Nav class="absolute z-10" />
|
||||
<header class="w-full h-3/6 sm:h-2/5 md:h-3/5">
|
||||
<div
|
||||
class="p-6 bg-[#1212121A] justify-center grid sm:grid-cols-12 gap-5 items-center sm:justify-start w-full h-full blur-background">
|
||||
<div
|
||||
class="sm:h-32 sm:!col-start-2 sm:col-span-8 md:col-span-6 lg:col-span-5 w-32 sm:w-fit max-h-full md:h-40 items-center grid grid-rows-1 grid-cols-1 sm:grid-cols-2 drop-shadow-md">
|
||||
<img alt="juls07 profile picture"
|
||||
src="~/assets/images/juls07.png"
|
||||
class="h-32 md:h-40 max-h-full rounded-full mb-3 sm:mb-0 sm:mr-2" />
|
||||
<div class="grid grid-rows-5 grid-cols-1 h-fit">
|
||||
<h1 class="text-4xl md:text-5xl row-span-3 font-jetbrains">Juls07</h1>
|
||||
<p class="text-[#00FFC2] row-span-2 md:text-lg h-fit">
|
||||
<span
|
||||
class="after:border after:h-[1.0em] after:border-current after:inline-block after:ml-0.5 after:animate-blink">
|
||||
{{ tagLine }}
|
||||
</span>
|
||||
</p>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</header>
|
||||
<main id="main"
|
||||
class="grid grid-cols-12 gap-5 justify-center">
|
||||
<section
|
||||
class="py-6 mb-4 !col-start-2 md:!col-start-3 lg:!col-start-4 lg:col-span-6 md:col-span-8 col-span-10">
|
||||
<h2 class="md:text-4xl text-3xl mb-1">About me</h2>
|
||||
<hr
|
||||
class="border-2 my-1.5 border-[#EB0066] rounded-md w-7/12 min-w-[200px] max-w-xs lg:max-w-sm mb-1" />
|
||||
<p class="max-w-md sm:max-w-xl md:max-w-3xl lg:max-w-4xl mb-4">
|
||||
Hi there, I'm juls07, I am 14 years old and I <span tabindex="0"
|
||||
class="love">love</span> web
|
||||
development. I first dabbled in web development
|
||||
when I was ten, and here we are today! I mainly use
|
||||
<a href="https://nuxtjs.org">NuxtJs</a> to
|
||||
build my websites since I absolutely
|
||||
adore Vuejs. For me, I love being able to imagine anything and it to come to life. Finally, go
|
||||
checkout my <a href="https://github.com/juls0730">Github</a> and also my <a
|
||||
href="https://twitter.com/julie4055_">Twitter</a>.
|
||||
</p>
|
||||
<h3 class="text-2xl md:text-3xl mb-1.5 ml-0.5">Skills</h3>
|
||||
<section class="flex flex-wrap w-full gap-2 justify-start ml-1">
|
||||
<IconTag name="TypeScript"
|
||||
iconName="skill-icons:typescript" />
|
||||
<IconTag name="Nuxt.js"
|
||||
iconName="skill-icons:nuxtjs-dark" />
|
||||
<IconTag name="Vue.js"
|
||||
iconName="skill-icons:vuejs-dark" />
|
||||
<IconTag name="Ruby on rails"
|
||||
iconName="skill-icons:rails" />
|
||||
<IconTag name="php"
|
||||
iconName="skill-icons:php-dark" />
|
||||
<IconTag name="React"
|
||||
iconName="skill-icons:react-dark" />
|
||||
<IconTag name="Bash"
|
||||
iconName="skill-icons:bash-dark" />
|
||||
<IconTag name="Tailwindcss"
|
||||
iconName="skill-icons:tailwindcss-dark" />
|
||||
<IconTag name="Rust"
|
||||
iconName="skill-icons:rust" />
|
||||
<IconTag name="Node.js"
|
||||
iconName="skill-icons:nodejs-dark" />
|
||||
<IconTag name="Svelte"
|
||||
iconName="skill-icons:svelte" />
|
||||
<IconTag name="Figma"
|
||||
iconName="skill-icons:figma-dark" />
|
||||
<IconTag name="Electron"
|
||||
iconName="skill-icons:electron" />
|
||||
<IconTag name="Cypress"
|
||||
iconName="logos:cypress-icon" />
|
||||
<IconTag name="Prisma"
|
||||
iconName="skill-icons:prisma" />
|
||||
<IconTag name="Docker"
|
||||
icon-name="skill-icons:docker" />
|
||||
</section>
|
||||
</section>
|
||||
<div class="!col-start-2 md:!col-start-3 lg:!col-start-4 lg:col-span-6 md:col-span-8 col-span-10">
|
||||
<h2 class="md:text-4xl text-3xl mb-1">Projects</h2>
|
||||
</div>
|
||||
<section
|
||||
class="pb-6 grid mb-4 col-start-2 xs:!col-start-3 col-span-10 xs:col-span-8 grid-cols-12 gap-y-6 sm:gap-x-6 max-w-full">
|
||||
<ProjectCard name="Juls07.dev V2"
|
||||
headerIcon="tabler:brand-nuxt"
|
||||
githubLink="https://github.com/juls0730/juls07.dev-v2"
|
||||
:icons="[{ 'icon': 'logos:nuxt-icon', 'name': 'nuxtjs v3' }]">
|
||||
this is a small forum project I made to mock my ruby on rails forum I am
|
||||
working on but in vuejs.
|
||||
</ProjectCard>
|
||||
<ProjectCard name="PHP Forum"
|
||||
headerIcon="mdi:language-php"
|
||||
githubLink="https://github.com/juls0730/php-forum"
|
||||
:icons="[{ 'icon': 'logos:laravel', 'name': 'php' }]">
|
||||
This is my attempt at a forum written in php, its not great but it works.
|
||||
</ProjectCard>
|
||||
<ProjectCard name="Cyansplash.net"
|
||||
headerIcon="tabler:brand-nuxt"
|
||||
githubLink="https://github.com/juls0730/cyansplash.net"
|
||||
:icons="[{ 'icon': 'logos:nuxt-icon', 'name': 'nuxtjs v2' }]">
|
||||
This is the old cyansplash.net site, not amazing but taught me a lot about web
|
||||
development.
|
||||
</ProjectCard>
|
||||
<ProjectCard name="Discord.js bot"
|
||||
headerIcon="mdi:robot-excited-outline"
|
||||
githubLink="https://github.com/juls0730/Echo"
|
||||
:icons="[{ 'icon': 'logos:javascript', 'name': 'Javascript' }]">
|
||||
This is one of the first projects that wasn't just a dinky website, this project brought me to where
|
||||
I am today.
|
||||
</ProjectCard>
|
||||
<ProjectCard name="juls07.dev V1"
|
||||
headerIcon="tabler:brand-nuxt"
|
||||
githubLink="https://github.com/juls0730/juls07.dev"
|
||||
:icons="[{ 'icon': 'logos:nuxt-icon', 'name': 'nuxtjs v2' }, { 'icon': 'logos:tailwindcss-icon', 'name': 'tailwindcss' }]">
|
||||
This stie is the site you are currently on, this site is just a place to show
|
||||
off my projects and my skills.
|
||||
</ProjectCard>
|
||||
<ProjectCard name="vuefullstack"
|
||||
headerIcon="tabler:brand-vue"
|
||||
githubLink="https://github.com/juls0730/vuefullstack"
|
||||
:icons="[{ 'icon': 'logos:vue', 'name': 'vue v3' }, { 'icon': 'logos:nodejs-icon', 'name': 'nodejs' }]">
|
||||
this is a small forum project I made to mock my ruby on rails forum I am
|
||||
working on but in vuejs.
|
||||
</ProjectCard>
|
||||
<ProjectCard name="100DaysOfCode"
|
||||
headerIcon="mdi:nodejs"
|
||||
githubLink="https://github.com/juls0730/vuefullstack"
|
||||
:icons="[{ 'icon': 'logos:nodejs-icon', 'name': 'nodejs' }]">
|
||||
This is my #100DaysOfCode challenge, my challenge was to create my own UI framework thing, check out a <nuxt-link to="/blog/100daysofcode-challenge">large overview of my 100DaysOfCode challenge</nuxt-link> on my blog.
|
||||
</ProjectCard>
|
||||
</section>
|
||||
</main>
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<style scoped>
|
||||
.blur-background {
|
||||
position: relative;
|
||||
overflow: hidden;
|
||||
}
|
||||
|
||||
.blur-background::before {
|
||||
content: '';
|
||||
margin: -35px;
|
||||
position: absolute;
|
||||
top: 0;
|
||||
right: 0;
|
||||
bottom: 0;
|
||||
left: 0;
|
||||
filter: blur(16px) saturate(125%);
|
||||
}
|
||||
|
||||
header,
|
||||
.blur-background::before {
|
||||
background-image: url(~/assets/images/header.jpg);
|
||||
background-position: center;
|
||||
background-repeat: no-repeat;
|
||||
background-size: cover;
|
||||
}
|
||||
</style>
|
||||
|
||||
<script setup lang="ts">
|
||||
let today = new Date();
|
||||
let age = today.getFullYear() - 2008;
|
||||
|
||||
if (new Date(today.getFullYear() + "-07-30") > today) {
|
||||
age--;
|
||||
}
|
||||
|
||||
useHead({
|
||||
title: 'Juls07',
|
||||
})
|
||||
@@ -211,4 +58,144 @@ export default {
|
||||
setTimeout(this.typeText, 2200);
|
||||
},
|
||||
}
|
||||
</script>
|
||||
</script>
|
||||
|
||||
<template>
|
||||
<div class="min-h-screen">
|
||||
<Nav class="absolute z-10 text-white" />
|
||||
<header class="w-full h-[50vh] sm:h-[40vh] md:h-[60vh]">
|
||||
<div
|
||||
class="p-6 bg-[#1212121A] justify-center grid sm:grid-cols-12 gap-5 items-center sm:justify-start w-full h-full blur-background">
|
||||
<div
|
||||
class="sm:h-32 sm:!col-start-2 sm:col-span-8 md:col-span-6 lg:col-span-5 w-32 sm:w-fit max-h-full md:h-40 items-center grid grid-rows-1 grid-cols-1 sm:grid-cols-2 drop-shadow-md">
|
||||
<img alt="juls07 profile picture" src="~/assets/images/juls07.png"
|
||||
class="h-32 md:h-40 max-h-full rounded-full mb-3 sm:mb-0 sm:mr-2" />
|
||||
<div class="grid grid-rows-5 grid-cols-1 h-fit">
|
||||
<h1 class="text-4xl md:text-5xl row-span-3 font-jetbrains text-white">Juls07</h1>
|
||||
<p class="text-sea-green row-span-2 md:text-lg h-fit">
|
||||
<span
|
||||
class="after:border after:h-[1.0em] after:border-current after:inline-block after:ml-0.5 after:animate-blink">
|
||||
{{ tagLine }}
|
||||
</span>
|
||||
</p>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</header>
|
||||
<main id="main" class="grid grid-cols-12 gap-5 justify-center">
|
||||
<section
|
||||
class="py-6 mb-4 !col-start-2 md:!col-start-3 lg:!col-start-4 lg:col-span-6 md:col-span-8 col-span-10">
|
||||
<h2 class="md:text-4xl text-3xl mb-1">About me</h2>
|
||||
<hr class="border-2 my-1.5 border-fuschia rounded-md w-7/12 min-w-[200px] max-w-xs lg:max-w-sm mb-1" />
|
||||
<p class="max-w-md sm:max-w-xl md:max-w-3xl lg:max-w-4xl mb-4">
|
||||
Hi there, I'm juls07, I am {{ age }} years old and I <span tabindex="0" class="love">love</span> web
|
||||
development. I first dabbled in web development
|
||||
when I was ten, and here we are today! I mainly use
|
||||
<a href="https://nuxt.com">NuxtJs</a> to
|
||||
build my websites since I absolutely
|
||||
adore Vuejs. For me, I love being able to imagine anything and it to come to life. Finally, go
|
||||
checkout my <a href="https://github.com/juls0730">Github</a> and also my <a
|
||||
href="https://twitter.com/julie4055_">Twitter</a>.
|
||||
</p>
|
||||
<h3 class="text-2xl md:text-3xl mb-1.5 ml-0.5">Skills</h3>
|
||||
<section class="flex flex-wrap w-full gap-2 justify-start ml-1">
|
||||
<IconTag name="TypeScript" iconName="skill-icons:typescript" />
|
||||
<IconTag name="Nuxt.js" iconName="skill-icons:nuxtjs-dark" />
|
||||
<IconTag name="Vue.js" iconName="skill-icons:vuejs-dark" />
|
||||
<IconTag name="Ruby on rails" iconName="skill-icons:rails" />
|
||||
<IconTag name="php" iconName="skill-icons:php-dark" />
|
||||
<IconTag name="React" iconName="skill-icons:react-dark" />
|
||||
<IconTag name="Bash" iconName="skill-icons:bash-dark" />
|
||||
<IconTag name="Tailwindcss" iconName="skill-icons:tailwindcss-dark" />
|
||||
<IconTag name="Rust" iconName="skill-icons:rust" />
|
||||
<IconTag name="Node.js" iconName="skill-icons:nodejs-dark" />
|
||||
<IconTag name="Svelte" iconName="skill-icons:svelte" />
|
||||
<IconTag name="Figma" iconName="skill-icons:figma-dark" />
|
||||
<IconTag name="Electron" iconName="skill-icons:electron" />
|
||||
<IconTag name="Cypress" iconName="skill-icons:cypress-dark" />
|
||||
<IconTag name="Prisma" iconName="skill-icons:prisma" />
|
||||
<IconTag name="Docker" icon-name="skill-icons:docker" />
|
||||
</section>
|
||||
</section>
|
||||
<div class="!col-start-2 md:!col-start-3 lg:!col-start-4 lg:col-span-6 md:col-span-8 col-span-10">
|
||||
<h2 class="md:text-4xl text-3xl mb-1">Projects</h2>
|
||||
</div>
|
||||
<section
|
||||
class="pb-6 grid mb-4 col-start-2 xs:!col-start-3 col-span-10 xs:col-span-8 grid-cols-12 gap-y-6 sm:gap-x-6 max-w-full">
|
||||
<ProjectCard name="Juls07.dev V2" headerIcon="tabler:brand-nuxt"
|
||||
githubLink="https://github.com/juls0730/juls07.dev-v2"
|
||||
:icons="[{ 'icon': 'logos:nuxt-icon', 'name': 'nuxtjs v3' }]">
|
||||
This is the site you're currently on, a simple but decent looking portfolio and blog site.
|
||||
</ProjectCard>
|
||||
<ProjectCard name="PHP Forum" headerIcon="mdi:language-php"
|
||||
githubLink="https://github.com/juls0730/php-forum"
|
||||
:icons="[{ 'icon': 'logos:laravel', 'name': 'php' }]">
|
||||
This is my attempt at a forum written in php, its not great but it works.
|
||||
</ProjectCard>
|
||||
<ProjectCard name="Cyansplash.net" headerIcon="tabler:brand-nuxt"
|
||||
githubLink="https://github.com/juls0730/cyansplash.net"
|
||||
:icons="[{ 'icon': 'logos:nuxt-icon', 'name': 'nuxtjs v2' }]">
|
||||
This is the old cyansplash.net site, not amazing but taught me a lot about web
|
||||
development.
|
||||
</ProjectCard>
|
||||
<ProjectCard name="Discord.js bot" headerIcon="mdi:robot-excited-outline"
|
||||
githubLink="https://github.com/juls0730/Echo"
|
||||
:icons="[{ 'icon': 'logos:javascript', 'name': 'Javascript' }]">
|
||||
This is one of the first projects that wasn't just a dinky website, this project brought me to where
|
||||
I am today.
|
||||
</ProjectCard>
|
||||
<ProjectCard name="juls07.dev V1" headerIcon="tabler:brand-nuxt"
|
||||
githubLink="https://github.com/juls0730/juls07.dev"
|
||||
:icons="[{ 'icon': 'logos:nuxt-icon', 'name': 'nuxtjs v2' }, { 'icon': 'logos:tailwindcss-icon', 'name': 'tailwindcss' }]">
|
||||
This is my original portfolio website, it isn't much and it definitely isn't the best thing I've
|
||||
ever written, but it's something.
|
||||
</ProjectCard>
|
||||
<ProjectCard name="vuefullstack" headerIcon="tabler:brand-vue"
|
||||
githubLink="https://github.com/juls0730/vuefullstack"
|
||||
:icons="[{ 'icon': 'logos:vue', 'name': 'vue v3' }, { 'icon': 'logos:nodejs-icon', 'name': 'nodejs' }]">
|
||||
This is a small forum project I made to mock my ruby on rails forum I am
|
||||
working on but in vuejs.
|
||||
</ProjectCard>
|
||||
<ProjectCard name="100DaysOfCode" headerIcon="mdi:nodejs"
|
||||
githubLink="https://github.com/juls0730/vuefullstack"
|
||||
:icons="[{ 'icon': 'logos:nodejs-icon', 'name': 'nodejs' }]">
|
||||
This is my #100DaysOfCode challenge, my challenge was to create my own UI framework thing, check out
|
||||
a
|
||||
<nuxt-link to="/blog/100daysofcode-challenge">large overview of my 100DaysOfCode
|
||||
challenge</nuxt-link> on my
|
||||
blog.
|
||||
</ProjectCard>
|
||||
</section>
|
||||
</main>
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<style>
|
||||
.blur-background {
|
||||
position: relative;
|
||||
overflow: hidden;
|
||||
}
|
||||
|
||||
#main a {
|
||||
@apply text-fuschia hover:underline visited:bg-rose-700;
|
||||
}
|
||||
|
||||
.blur-background::before {
|
||||
content: '';
|
||||
margin: -35px;
|
||||
position: absolute;
|
||||
top: 0;
|
||||
right: 0;
|
||||
bottom: 0;
|
||||
left: 0;
|
||||
filter: blur(16px) saturate(125%);
|
||||
}
|
||||
|
||||
header,
|
||||
.blur-background::before {
|
||||
background-image: url(~/assets/images/header.jpg);
|
||||
background-position: center;
|
||||
background-repeat: no-repeat;
|
||||
background-size: cover;
|
||||
}
|
||||
</style>
|
||||
|
||||
Reference in New Issue
Block a user