Website Update

This commit is contained in:
2026-02-01 13:14:14 -05:00
parent 0bfc7a9e7a
commit 5244522239
7 changed files with 184 additions and 113 deletions

View File

@@ -10,27 +10,27 @@
"start": "vite build && bun server/server.js" "start": "vite build && bun server/server.js"
}, },
"devDependencies": { "devDependencies": {
"@sveltejs/adapter-node": "^5.4.0", "@sveltejs/adapter-node": "^5.5.2",
"@sveltejs/kit": "^2.49.2", "@sveltejs/kit": "^2.50.1",
"@sveltejs/vite-plugin-svelte": "^6.2.1", "@sveltejs/vite-plugin-svelte": "^6.2.4",
"@tailwindcss/forms": "^0.5.11", "@tailwindcss/forms": "^0.5.11",
"@tailwindcss/typography": "^0.5.19", "@tailwindcss/typography": "^0.5.19",
"@tailwindcss/vite": "^4.1.18", "@tailwindcss/vite": "^4.1.18",
"svelte": "^5.46.0", "svelte": "^5.49.1",
"svelte-check": "^4.3.4", "svelte-check": "^4.3.6",
"tailwindcss": "^4.1.18", "tailwindcss": "^4.1.18",
"typescript": "^5.9.3", "typescript": "^5.9.3",
"vite": "^7.3.0" "vite": "^7.3.1"
}, },
"dependencies": { "dependencies": {
"@iconify/svelte": "^5.1.0", "@iconify/svelte": "^5.2.1",
"@threlte/core": "^8.3.1", "@threlte/core": "^8.3.1",
"@types/three": "^0.181.0", "@types/three": "^0.181.0",
"cors": "^2.8.5", "cors": "^2.8.6",
"discord.js": "^14.25.1", "discord.js": "^14.25.1",
"dotenv": "^17.2.3", "dotenv": "^17.2.3",
"express": "^5.2.1", "express": "^5.2.1",
"hotkeys-js": "^4.0.0-beta.7", "hotkeys-js": "^4.0.0",
"play-dl": "^1.9.7", "play-dl": "^1.9.7",
"three": "^0.181.2" "three": "^0.181.2"
} }

View File

@@ -2,7 +2,47 @@
// PROJECTS // PROJECTS
// ============================================================================ // ============================================================================
export interface Project { export interface OpenSourceProject {
name: string;
description: string;
tech: string[];
github?: string;
live?: string;
image?: string;
}
export const openSourceProjects: OpenSourceProject[] = [
{
name: 'Pkit',
description: 'CLI toolkit and utilities (Rust project) — small developer-focused CLI.',
tech: ['Rust', 'CLI'],
live: 'https://pkit.sirblob.co/',
github: 'https://github.com/dead-projects-inc/pkit-cli',
image: 'https://icons.veryicon.com/png/o/business/vscode-program-item-icon/rust-1.png',
},
{
name: 'OBookLLM',
description: "OBookLLM is a powerful, self-hosted, offline-capable alternative to NotebookLLM.",
tech: ['Python', 'LLM', 'AI', 'NotebookLLM'],
github: 'https://github.com/SirBlobby/OBookLLM',
image: 'https://upload.wikimedia.org/wikipedia/commons/c/c3/Python-logo-notext.svg',
},
{
name: 'Filaprint',
description: 'Filaprint is a web application to help 3D printing enthusiasts manage their filament inventory, track print jobs, view 3D models, and calculate costs and energy usage.',
tech: ['Sveltekit', 'Management', '3D Printing'],
github: 'https://github.com/SirBlobby/Filaprint',
image: 'https://repository-images.githubusercontent.com/354583933/72c58c80-9727-11eb-98b2-f352fded32b9',
}
];
// ============================================================================
// PACKAGES
// ============================================================================
export interface PackageProject {
name: string; name: string;
description: string; description: string;
tech: string[]; tech: string[];
@@ -12,7 +52,7 @@ export interface Project {
featured?: boolean; featured?: boolean;
} }
export const projects: Project[] = [ export const packageProjects: PackageProject[] = [
{ {
name: 'PokemonTCGAPI', name: 'PokemonTCGAPI',
description: 'UnOfficial NPM package wrapper for the PokemonTCG API.', description: 'UnOfficial NPM package wrapper for the PokemonTCG API.',
@@ -36,15 +76,6 @@ export const projects: Project[] = [
live: 'https://www.npmjs.com/package/@sirblob/mcp-selenium', live: 'https://www.npmjs.com/package/@sirblob/mcp-selenium',
image: 'https://upload.wikimedia.org/wikipedia/commons/thumb/d/db/Npm-logo.svg/1200px-Npm-logo.svg.png', image: 'https://upload.wikimedia.org/wikipedia/commons/thumb/d/db/Npm-logo.svg/1200px-Npm-logo.svg.png',
featured: true featured: true
},
{
name: 'Pkit',
description: 'CLI toolkit and utilities (Rust project) — small developer-focused CLI.',
tech: ['Rust', 'CLI'],
live: 'https://pkit.sirblob.co/',
github: 'https://github.com/dead-projects-inc/pkit-cli',
image: 'https://icons.veryicon.com/png/o/business/vscode-program-item-icon/rust-1.png',
featured: false
} }
]; ];
@@ -91,7 +122,7 @@ export const models: Model3D[] = [
export type Card = { export type Card = {
title: string; title: string;
description: string; description: string;
image?: string; image?: string | null;
link?: string; link?: string;
repo?: string; repo?: string;
devpost?: string; devpost?: string;
@@ -197,8 +228,22 @@ export const cards: Card[] = [
location: "Blacksburg, VA", location: "Blacksburg, VA",
year: "2025", year: "2025",
tags: ["react", "node.js", "python", "mongodb", "geospatial", "mapbox"], tags: ["react", "node.js", "python", "mongodb", "geospatial", "mapbox"],
featured: true, featured: false,
liveWarning: true liveWarning: true
},
{
image: "/img/hoya26.png",
title: "Ethix",
description: "A sustainability platform that helps users detect and report greenwashing - misleading environmental claims made by companies and products.",
repo: "https://github.com/SirBlobby/Hoya26",
devpost: "https://devpost.com/software/ethix",
link: "https://ethix.sirblob.co/",
hackathonName: "HoyaHax 2026",
university: "Georgetown University",
location: "Washington, D.C.",
year: "2026",
tags: ["Svelte", "TypeScript", "Python", "Flask", "Tailwind", "Sustainability"],
featured: true
} }
]; ];

View File

@@ -26,8 +26,8 @@ export {
} from './theme'; } from './theme';
// Content: projects, models, hackathon cards // Content: projects, models, hackathon cards
export type { Project, Model3D, Card } from './content'; export type { OpenSourceProject, PackageProject, Model3D, Card } from './content';
export { projects, models, cards, sortedCards } from './content'; export { openSourceProjects, packageProjects, models, cards, sortedCards } from './content';
// Terminal settings, TUI styling, speed presets, model viewer, particles, shortcuts // Terminal settings, TUI styling, speed presets, model viewer, particles, shortcuts
export type { SpeedPreset, TerminalSettings } from './terminal'; export type { SpeedPreset, TerminalSettings } from './terminal';

View File

@@ -1,20 +1,20 @@
import type { TerminalLine } from '$lib/components/tui/types'; import type { TerminalLine } from '$lib/components/tui/types';
import { user } from '$lib/config'; import { user } from '$lib/config';
const artist = [ // const artist = [
{ // {
name: 'Noah Floersch', // name: 'Noah Floersch',
url: 'https://music.youtube.com/channel/UCgPjhKqPg5cPxErhqnoPlWg?si=B7GEz2QMNtrgnAbz' // url: 'https://music.youtube.com/channel/UCgPjhKqPg5cPxErhqnoPlWg?si=B7GEz2QMNtrgnAbz'
}, // },
{ // {
name: 'Laufey', // name: 'Laufey',
url: 'https://music.youtube.com/channel/UCJtROTPxo3qnEzww8JyDxuA?si=WwgYFkoccnXtJ6Im' // url: 'https://music.youtube.com/channel/UCJtROTPxo3qnEzww8JyDxuA?si=WwgYFkoccnXtJ6Im'
}, // },
{ // {
name: 'Tate McRae', // name: 'Tate McRae',
url: 'https://music.youtube.com/channel/UCz86IA7ooUetFnUGa_YlsVw?si=A1t0-hLHswhbEG0U' // url: 'https://music.youtube.com/channel/UCz86IA7ooUetFnUGa_YlsVw?si=A1t0-hLHswhbEG0U'
} // }
] // ]
const hobbies = [ const hobbies = [
{ {
@@ -152,7 +152,7 @@ export const lines: TerminalLine[] = [
{ type: 'link', href: "/about#games", content: `(&bg-orange, black, bold)Games(&)`, inline: true }, { type: 'link', href: "/about#games", content: `(&bg-orange, black, bold)Games(&)`, inline: true },
{ type: 'link', href: "/about#shows", content: `(&bg-yellow, black, bold)Shows(&)`, inline: true }, { type: 'link', href: "/about#shows", content: `(&bg-yellow, black, bold)Shows(&)`, inline: true },
{ type: 'link', href: "/about#movies", content: `(&bg-green, black, bold)Movies(&)`, inline: true }, { type: 'link', href: "/about#movies", content: `(&bg-green, black, bold)Movies(&)`, inline: true },
{ type: 'link', href: "/about#music", content: `(&bg-accent, black, bold)Music(&)`, inline: true }, // { type: 'link', href: "/about#music", content: `(&bg-accent, black, bold)Music(&)`, inline: true },
] ]
}, },
@@ -240,22 +240,22 @@ export const lines: TerminalLine[] = [
{ type: 'blank', content: '' }, { type: 'blank', content: '' },
{ type: 'divider', content: 'Music Recommendations', id: 'music' }, // { type: 'divider', content: 'Music Recommendations', id: 'music' },
{ // {
type: 'group', // type: 'group',
content: '', // content: '',
groupDirection: 'row', // groupDirection: 'row',
children: [ // children: [
{ type: 'output', content: '(&accent)Artists:(&) ', inline: true }, // { type: 'output', content: '(&accent)Artists:(&) ', inline: true },
...artist.flatMap((a, i): TerminalLine[] => { // ...artist.flatMap((a, i): TerminalLine[] => {
const item: TerminalLine = { type: 'link', content: `(&primary)${a.name}(&)`, href: a.url, inline: true }; // const item: TerminalLine = { type: 'link', content: `(&primary)${a.name}(&)`, href: a.url, inline: true };
return i < artist.length - 1 ? [item, { type: 'output', content: ' (&muted)•(&) ', inline: true }] : [item]; // return i < artist.length - 1 ? [item, { type: 'output', content: ' (&muted)•(&) ', inline: true }] : [item];
}), // }),
] // ]
}, // },
{ type: 'blank', content: '' }, // { type: 'blank', content: '' },
// { // {
// type: 'card', // type: 'card',
// id: 'music-player', // id: 'music-player',

View File

@@ -1,6 +1,22 @@
import type { TerminalLine } from '$lib/components/tui/types'; import type { TerminalLine } from '$lib/components/tui/types';
import { user, skills, projects } from '$lib/config'; import { user, skills, openSourceProjects } from '$lib/config';
const openSourceElements:TerminalLine[] = [];
openSourceProjects.forEach(project => {
openSourceElements.push(
{
type: 'output',
content: `(&orange,bold)▸ ${project.name}(&) - ${project.description}`
},
{
type: 'output',
content: ` ${project.tech.map(tech => `(&blue)${tech}(&)`).join(' (&muted)•(&) ')}`
},
{ type: 'blank', content: '' }
);
});
export const lines: TerminalLine[] = [ export const lines: TerminalLine[] = [
// Header command // Header command
@@ -25,6 +41,7 @@ export const lines: TerminalLine[] = [
] ]
}, },
{ type: 'blank', content: '' },
{ type: 'blank', content: '' }, { type: 'blank', content: '' },
{ {
type: 'group', content: '', groupAlign: 'start', groupGap: '1rem', type: 'group', content: '', groupAlign: 'start', groupGap: '1rem',
@@ -86,49 +103,7 @@ export const lines: TerminalLine[] = [
{ type: 'divider', content: 'PROJECTS', id: 'projects' }, { type: 'divider', content: 'PROJECTS', id: 'projects' },
// Featured projects with buttons ...openSourceElements,
...projects.filter(p => p.featured).flatMap(project => [
{ type: 'header' as const, content: `(&bold)${project.name}(&)` },
{ type: 'output' as const, content: `(&muted)${project.description}(&)` },
{ type: 'info' as const, content: `(&info)TechStack:(&) (&magenta)${project.tech.join(', ')}(&)` },
...(project.github ? [{
type: 'button' as const,
content: 'View on GitHub',
icon: 'mdi:github',
style: 'accent' as const,
href: project.github
}] : []),
...(project.live ? [{
type: 'button' as const,
content: 'View Live Demo',
icon: 'mdi:open-in-new',
style: 'accent' as const,
href: project.live
}] : []),
{ type: 'blank' as const, content: '' }
]),
// Other projects
...projects.filter(p => !p.featured).flatMap(project => [
{ type: 'success' as const, content: `(&success)${project.name}(&)` },
{ type: 'output' as const, content: `(&muted)${project.description}(&)` },
{ type: 'info' as const, content: `(&info)TechStack:(&) (&magenta)${project.tech.join(', ')}(&)` },
...(project.github ? [{
type: 'button' as const,
content: 'View on GitHub',
icon: 'mdi:github',
style: 'accent' as const,
href: project.github
}] : []),
...(project.live ? [{
type: 'button' as const,
content: 'View Live',
icon: 'mdi:open-in-new',
style: 'accent' as const,
href: project.live
}] : []),
{ type: 'blank' as const, content: '' }
]),
// End // End
{ type: 'success', content: `(&success)Portfolio loaded successfully!(&)` } { type: 'success', content: `(&success)Portfolio loaded successfully!(&)` }

View File

@@ -1,16 +1,67 @@
import type { TerminalLine } from '$lib/components/tui/types'; import type { TerminalLine } from '$lib/components/tui/types';
import { sortedCards, projects } from '$lib/config'; import { sortedCards, packageProjects, openSourceProjects } from '$lib/config';
const totalHackathons = sortedCards.length; const totalHackathons = sortedCards.length;
const totalAwards = sortedCards.filter(c => c.awards && c.awards.length > 0).length; const totalAwards = sortedCards.filter(c => c.awards && c.awards.length > 0).length;
const featuredCount = sortedCards.filter(c => c.featured).length; const featuredCount = sortedCards.filter(c => c.featured).length;
const openSourceElements:TerminalLine[] = [];
openSourceProjects.forEach(project => {
openSourceElements.push(
{
type: 'card',
content: '',
cardTitle: project.name,
// cardFooter: '' + (project.github ? `(&muted)GitHub:(&) (&link)${project.github}(&)` : ''),
image: project.image || '/images/placeholder.png',
imageAlt: 'Placeholder image',
children: [
...project.tech.map(tech => ({
type: 'output' as const,
content: `(&bg-blue, black)${tech}(&)`,
inline: true
})),
{
type: 'button',
content: 'View on GitHub',
href: project.github || 'https://github.com/',
icon: 'mdi:github',
style: 'accent',
},
project.live ? {
type: 'button',
content: 'View Live Demo',
href: project.live,
icon: 'mdi:open-in-new',
style: 'primary'
} : { type: 'blank', content: '' }
],
inline: true,
display: 'flex',
cardWidth: '275px'
},
);
});
// Build the terminal lines with card grid // Build the terminal lines with card grid
export const lines: TerminalLine[] = [ export const lines: TerminalLine[] = [
{ type: 'command', content: 'ls ~/projects' }, { type: 'command' as const, content: 'ls ~/projects' },
{ type: 'divider', content: 'PROJECTS' }, {
...projects.filter(p => p.featured).flatMap(project => [ type: 'group' as const, content: '', groupAlign: 'start', groupGap: '1rem',
{ type: 'header' as const, content: `(&bold)${project.name}(&)` }, children: [
{ type: 'link' as const, href: "/projects#opensource", content: `(&bg-blue,black)Open Scourced(&)`, inline: true },
{ type: 'link' as const, href: "/projects#packages", content: `(&bg-orange,black)Packages(&)`, inline: true },
{ type: 'link' as const, href: "/projects#hackathons", content: `(&bg-green,black)Hackathons(&)`, inline: true },
]
},
{ type: 'divider' as const, content: 'OPEN SOURCED', id: 'opensource' },
...openSourceElements,
{ type: 'divider' as const, content: 'PACKAGES', id: 'packages' },
...packageProjects.filter(p => p.featured).flatMap(project => [
{ type: 'header' as const, content: `(&orange)${project.name}(&)` },
{ type: 'output' as const, content: `(&muted)${project.description}(&)` }, { type: 'output' as const, content: `(&muted)${project.description}(&)` },
{ type: 'info' as const, content: `(&info)TechStack:(&) (&magenta)${project.tech.join(', ')}(&)` }, { type: 'info' as const, content: `(&info)TechStack:(&) (&magenta)${project.tech.join(', ')}(&)` },
...(project.github ? [{ ...(project.github ? [{
@@ -29,8 +80,8 @@ export const lines: TerminalLine[] = [
}] : []), }] : []),
{ type: 'blank' as const, content: '' } { type: 'blank' as const, content: '' }
]), ]),
...projects.filter(p => !p.featured).flatMap(project => [ ...packageProjects.filter(p => !p.featured).flatMap(project => [
{ type: 'success' as const, content: `(&success)${project.name}(&)` }, { type: 'header' as const, content: `${project.name}` },
{ type: 'output' as const, content: `(&muted)${project.description}(&)` }, { type: 'output' as const, content: `(&muted)${project.description}(&)` },
{ type: 'info' as const, content: `(&info)TechStack:(&) (&magenta)${project.tech.join(', ')}(&)` }, { type: 'info' as const, content: `(&info)TechStack:(&) (&magenta)${project.tech.join(', ')}(&)` },
...(project.github ? [{ ...(project.github ? [{
@@ -49,13 +100,13 @@ export const lines: TerminalLine[] = [
}] : []), }] : []),
{ type: 'blank' as const, content: '' } { type: 'blank' as const, content: '' }
]), ]),
{ type: 'divider', content: 'HACKATHONS' }, { type: 'divider' as const, content: 'HACKATHONS', id: 'hackathons' },
{ type: 'command', content: 'ls ~/hackathons --grid' }, // { type: 'command', content: 'ls ~/hackathons --grid' },
{ type: 'blank', content: '' }, { type: 'blank' as const, content: '' },
{ type: 'header', content: `Hackathon Journey` }, { type: 'header' as const, content: `Hackathon Journey` },
{ type: 'output', content: `(&muted)Total:(&) (&primary)${totalHackathons}(&) (&muted)| Awards:(&) (&yellow)${totalAwards}(&) (&muted)| Featured:(&) (&accent)${featuredCount}(&)` }, { type: 'output' as const, content: `(&muted)Total:(&) (&primary)${totalHackathons}(&) (&muted)| Awards:(&) (&yellow)${totalAwards}(&) (&muted)| Featured:(&) (&accent)${featuredCount}(&)` },
{ type: 'blank', content: '' }, { type: 'blank' as const, content: '' },
{ type: 'cardgrid', content: '', cards: sortedCards }, { type: 'cardgrid' as const, content: '', cards: sortedCards },
{ type: 'blank', content: '' }, { type: 'blank' as const, content: '' },
{ type: 'success', content: `(&success)Ready for the next hackathon! 🚀(&)` }, { type: 'success' as const, content: `(&success)Ready for the next hackathon! 🚀(&)` },
]; ];

BIN
static/img/hoya26.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 474 KiB