feat: add AboutSummary component with personal introduction and game preview
feat: create Chip component for displaying technology tags feat: implement ExperienceCard component to showcase job experiences feat: add Experience component to list multiple job experiences feat: create Footer component with social links and copyright information feat: implement Hero component for the landing section with social links feat: add ImageCarousel component for displaying project images feat: create Navbar component with scroll effect and navigation links feat: implement ProjectItem component to display individual project details feat: add Skills component to showcase technical skills feat: create data module with skills, jobs, and projects information feat: define types for Skill, Job, and Project in types module chore: update package.json with new dependencies for Tailwind CSS and Lucide icons chore: add CV PDF file to public directory chore: remove unused SVG files from public directory chore: add new images for background and hero sections feat: implement formatDate utility function for date formatting
This commit is contained in:
88
components/footer.tsx
Normal file
88
components/footer.tsx
Normal file
@@ -0,0 +1,88 @@
|
||||
import Link from "next/link";
|
||||
import { Github, Linkedin, Gamepad2 } from "lucide-react";
|
||||
|
||||
const Footer = () => {
|
||||
const currentYear = new Date().getFullYear();
|
||||
|
||||
const socialLinks = [
|
||||
{
|
||||
title: "github",
|
||||
href: "https://github.com/GKaszewski",
|
||||
icon: <Github />,
|
||||
},
|
||||
{
|
||||
title: "linkedin",
|
||||
href: "https://www.linkedin.com/in/gabriel-kaszewski-5344b3183",
|
||||
icon: <Linkedin />,
|
||||
},
|
||||
{
|
||||
title: "itch.io",
|
||||
href: "https://gabrielkaszewski.itch.io/",
|
||||
icon: <Gamepad2 />,
|
||||
},
|
||||
];
|
||||
|
||||
return (
|
||||
<footer className="flex w-full flex-col gap-4 bg-gray-900 p-4 text-white">
|
||||
<div className="flex items-center gap-2">
|
||||
<h1 className="text-xl">Gabriel Kaszewski</h1>
|
||||
<span className="flex-1"></span>
|
||||
<div className="flex gap-2">
|
||||
{socialLinks.map((link) => (
|
||||
<a
|
||||
key={link.title}
|
||||
title={link.title}
|
||||
href={link.href}
|
||||
target="_blank"
|
||||
rel="noopener noreferrer"
|
||||
className="hover:text-yellow-400 transition-colors"
|
||||
>
|
||||
{link.icon}
|
||||
</a>
|
||||
))}
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div className="text-sm">
|
||||
<p>
|
||||
Background photo by{" "}
|
||||
<a className="underline" href="https://duckwithsunglasses.com">
|
||||
Liam
|
||||
</a>
|
||||
</p>
|
||||
</div>
|
||||
|
||||
<div className="flex flex-wrap gap-x-4 gap-y-2 text-sm">
|
||||
<p className="font-semibold">
|
||||
© Gabriel Kaszewski, {currentYear}. All rights reserved.
|
||||
</p>
|
||||
<p>Made with 💗 in Poland</p>
|
||||
<span className="flex-1"></span>
|
||||
<div className="flex gap-4">
|
||||
<Link
|
||||
href="/projects"
|
||||
className="hover:text-yellow-400 transition-colors"
|
||||
>
|
||||
Projects
|
||||
</Link>
|
||||
<a
|
||||
href="https://blog.gabrielkaszewski.dev/"
|
||||
target="_blank"
|
||||
rel="noopener noreferrer"
|
||||
className="hover:text-yellow-400 transition-colors"
|
||||
>
|
||||
Blog
|
||||
</a>
|
||||
<Link
|
||||
href="/about"
|
||||
className="hover:text-yellow-400 transition-colors"
|
||||
>
|
||||
About
|
||||
</Link>
|
||||
</div>
|
||||
</div>
|
||||
</footer>
|
||||
);
|
||||
};
|
||||
|
||||
export default Footer;
|
Reference in New Issue
Block a user