Some checks failed
Build and Deploy Gabriel Kaszewski Portfolio / build-and-deploy-local (push) Failing after 12s
219 lines
7.3 KiB
TypeScript
219 lines
7.3 KiB
TypeScript
import Image from "next/image";
|
||
import Chip from "@/components/chip";
|
||
import { Metadata } from "next";
|
||
import { Check } from "lucide-react";
|
||
|
||
export const metadata: Metadata = {
|
||
title: "About Me | Gabriel Kaszewski",
|
||
description:
|
||
"Learn more about Gabriel Kaszewski, his skills, and his journey as a developer.",
|
||
};
|
||
|
||
const hobbies = [
|
||
"Programming 💻",
|
||
"Filmmaking 🎥",
|
||
"Gaming 🕹️",
|
||
"Playing guitar 🎸",
|
||
];
|
||
const interests = [
|
||
"Computer Science 💾",
|
||
"Sci-Fi Books📚",
|
||
"Astronomy 🔭",
|
||
"Sports 🏅",
|
||
"History 🏰",
|
||
];
|
||
const futureGoals = [
|
||
"Deepen my expertise in Rust for high-performance applications.",
|
||
"Contribute to impactful open-source projects.",
|
||
"Develop and release my first full-fledged indie game.",
|
||
];
|
||
const faqItems = [
|
||
{
|
||
q: "How old were you when you started programming?",
|
||
a: "I was 11 years old 🧑💻.",
|
||
},
|
||
{
|
||
q: "How did you learn programming?",
|
||
a: "I read books 📖 and practiced a lot.",
|
||
},
|
||
{
|
||
q: "Are you studying Computer Science?",
|
||
a: "No, I have a degree in Bioinformatics, which is a closely related field.",
|
||
},
|
||
{
|
||
q: "Which programming language do you recommend for a beginner?",
|
||
a: "The language doesn't really matter, just choose one you like and dive in 🌊.",
|
||
},
|
||
{
|
||
q: "What was your first programming language?",
|
||
a: "My journey began with C++ 🖥️.",
|
||
},
|
||
{
|
||
q: "What is your favorite programming language?",
|
||
a: "I enjoy writing in C, Rust, and Python 🐍. But Rust is the best 💖🦀",
|
||
},
|
||
];
|
||
|
||
const calculateAge = (birthDate: string): number => {
|
||
const today = new Date();
|
||
const birth = new Date(birthDate);
|
||
let age = today.getFullYear() - birth.getFullYear();
|
||
const monthDifference = today.getMonth() - birth.getMonth();
|
||
if (
|
||
monthDifference < 0 ||
|
||
(monthDifference === 0 && today.getDate() < birth.getDate())
|
||
) {
|
||
age--;
|
||
}
|
||
return age;
|
||
};
|
||
|
||
const AboutPage = () => {
|
||
const age = calculateAge("2002-02-27");
|
||
|
||
return (
|
||
<div className="flex w-full flex-col items-center gap-8 p-4 pt-24 text-white">
|
||
<div className="flex flex-col items-center justify-center gap-2 p-4 backdrop-blur-sm glass-effect glossy-effect bottom gloss-highlight rounded-lg shadow-lg">
|
||
<Image
|
||
src="/images/ja.avif"
|
||
alt="A photo of Gabriel Kaszewski"
|
||
width={300}
|
||
height={300}
|
||
className="object-cover rounded-md shadow-lg"
|
||
priority
|
||
/>
|
||
<h2 className="mt-4 text-2xl font-bold">Hello, I'm Gabriel! 👋</h2>
|
||
</div>
|
||
|
||
<div className="prose prose-invert lg:prose-lg xl:prose-xl max-w-3xl mx-auto w-full">
|
||
<section id="more-info">
|
||
<h1 className="text-center">More info about me! 💡</h1>
|
||
<p>
|
||
Hi! I am Gabriel and I am {age} years old. I graduated in
|
||
Bioinformatics from the University of Gdańsk 🏫. I'm fluent in
|
||
Polish and English and currently work as a Python Developer at
|
||
digimonkeys.com 🐒💻.
|
||
</p>
|
||
<p>
|
||
I have co-authored one scientific article, which you can read{" "}
|
||
<a
|
||
target="_blank"
|
||
href="http://dx.doi.org/10.1038/s41598-023-44488-7"
|
||
className="text-yellow-400 underline"
|
||
>
|
||
here
|
||
</a>
|
||
.
|
||
</p>
|
||
<p>
|
||
My bachelor's thesis titled "Modeling evolutionary
|
||
processes using cellular automata" is available{" "}
|
||
<a
|
||
target="_blank"
|
||
href="/licencjat.pdf"
|
||
className="text-yellow-400 underline"
|
||
>
|
||
here
|
||
</a>
|
||
, the thesis is written in Polish.
|
||
</p>
|
||
</section>
|
||
|
||
<section
|
||
id="hobbies&interests"
|
||
className="not-prose flex flex-col sm:flex-row gap-8 mt-12"
|
||
>
|
||
<div className="flex-1">
|
||
<h2 className="text-center">Hobbies 🎮🎸</h2>
|
||
<div className="flex flex-wrap items-center justify-center gap-4 mt-4">
|
||
{hobbies.map((hobby) => (
|
||
<Chip key={hobby} text={hobby} />
|
||
))}
|
||
</div>
|
||
</div>
|
||
<div className="flex-1">
|
||
<h2 className="text-center">Interests 🌌📚</h2>
|
||
<div className="flex flex-wrap items-center justify-center gap-4 mt-4">
|
||
{interests.map((interest) => (
|
||
<Chip key={interest} text={interest} />
|
||
))}
|
||
</div>
|
||
</div>
|
||
</section>
|
||
|
||
<section id="philosophy" className="mt-12">
|
||
<h1>My Philosophy 🧠</h1>
|
||
<p>
|
||
I believe much of today's software is bloated, inefficient, and
|
||
disrespectful of the user's resources. My passion, which
|
||
started with a simple curiosity at age 11, is to build a better
|
||
alternative. I focus on creating software that is{" "}
|
||
<strong className="text-yellow-400">
|
||
fast, reliable, and genuinely intuitive
|
||
</strong>
|
||
, guided by the principles of clean and efficient code.
|
||
</p>
|
||
</section>
|
||
|
||
<section id="toolkit">
|
||
<h1>My Toolkit 🛠️</h1>
|
||
<div className="not-prose bg-black/20 backdrop-blur-sm glass-effect rounded-2xl p-4 text-white text-shadow-sm">
|
||
<div className="grid grid-cols-1 md:grid-cols-2 gap-4">
|
||
<div>
|
||
<h3 className="text-xl font-bold">OS & Hardware</h3>
|
||
<p>
|
||
Arch Linux, Custom-built PC (Ryzen 7 5800X3D, RTX 4070 Ti,
|
||
48GB RAM)
|
||
</p>
|
||
</div>
|
||
<div>
|
||
<h3 className="text-xl font-bold">Editor</h3>
|
||
<p>Jetbrains IDEs (Pycharm, Rider) & VS Code</p>
|
||
</div>
|
||
<div>
|
||
<h3 className="text-xl font-bold">Primary Languages</h3>
|
||
<p>Rust, Python, C#, TypeScript</p>
|
||
</div>
|
||
<div>
|
||
<h3 className="text-xl font-bold">Favorite Tech</h3>
|
||
<p>Axum, Godot, React, TailwindCSS</p>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
</section>
|
||
|
||
<section id="future-goals" className="mt-12">
|
||
<h1>Future Goals 🚀</h1>
|
||
<p>
|
||
I'm always eager to learn and grow. My goal is to continue
|
||
honing my skills in backend development and system architecture.
|
||
Here's what's on my radar:
|
||
</p>
|
||
<ul className="list-none p-0">
|
||
{futureGoals.map((goal) => (
|
||
<li key={goal} className="flex items-center gap-2 not-prose mb-2">
|
||
<Check className="text-yellow-400 flex-shrink-0" size={20} />
|
||
<span>{goal}</span>
|
||
</li>
|
||
))}
|
||
</ul>
|
||
</section>
|
||
|
||
<section id="faq" className="mt-12">
|
||
<h1>FAQ ❓</h1>
|
||
<div className="not-prose flex flex-col gap-4">
|
||
{faqItems.map((item) => (
|
||
<div key={item.q}>
|
||
<h3 className="text-xl font-bold">{item.q}</h3>
|
||
<p>{item.a}</p>
|
||
</div>
|
||
))}
|
||
</div>
|
||
</section>
|
||
</div>
|
||
</div>
|
||
);
|
||
};
|
||
|
||
export default AboutPage;
|