Compare commits

...
Sign in to create a new pull request.

1 commit

Author SHA1 Message Date
741a1b6429 interim commit 2026-03-01 15:24:59 +00:00
10 changed files with 332 additions and 326 deletions

View file

@ -37,8 +37,8 @@ const EolasListing = () => {
<div className="container mx-auto py-4 px-1 md:p-4 grow"> <div className="container mx-auto py-4 px-1 md:p-4 grow">
<div className="space-my-8"> <div className="space-my-8">
<section className="container"> <section className="container">
<h2 className="text-2xl font-semibold mb-4 text-[#d65d0e]! h2-home scanlined px-2"> <h2 className="text-2xl font-semibold mb-4 text-[#d65d0e]! h2-home">
{`eolas recent`} {`Recent learning`}
</h2> </h2>
{isLoading && <div>Loading...</div>} {isLoading && <div>Loading...</div>}

View file

@ -2,7 +2,7 @@ import MetricBar from "./MetricBar"
const LanguagesChart = ({ chartData, error }) => { const LanguagesChart = ({ chartData, error }) => {
return ( return (
<div className="bg-sidebar p-3 my-4"> <div className="bg-sidebar p-3 my-4 mx-2 rounded-2xl">
<div className="text-muted-foreground text-sm pb-2"> <div className="text-muted-foreground text-sm pb-2">
programming languages programming languages
</div> </div>

View file

@ -1,6 +1,6 @@
const Scorecard = ({ title, metric }) => { const Scorecard = ({ title, metric }) => {
return ( return (
<div className="bg-sidebar p-3"> <div className="bg-sidebar p-3 rounded-2xl">
<div className="text-muted-foreground text-sm">{title}</div> <div className="text-muted-foreground text-sm">{title}</div>
<div className="text-lg">{metric}</div> <div className="text-lg">{metric}</div>
</div> </div>

View file

@ -71,7 +71,7 @@ const CodeStats = () => {
<div className="space-my-8"> <div className="space-my-8">
<section className="container"> <section className="container">
<div className="flex flex-col md:flex-row items-start md:items-center md:justify-between"> <div className="flex flex-col md:flex-row items-start md:items-center md:justify-between">
<h2 className="text-2xl font-semibold mb-4 text-[#458588]! h2-home scanlined px-2"> <h2 className="text-3xl font-semibold mb-4 text-[#458588]! h2-home">
{`code stats`} {`code stats`}
</h2> </h2>
<div className="mb-4 text-sm text-muted"> <div className="mb-4 text-sm text-muted">
@ -79,7 +79,7 @@ const CodeStats = () => {
{convertDateFriendly(data?.to)} {convertDateFriendly(data?.to)}
</div> </div>
</div> </div>
<div className="grid grid-cols-1 md:grid-cols-2 lg:grid-cols-3 gap-4"> <div className="grid grid-cols-1 md:grid-cols-2 lg:grid-cols-3 gap-4 mx-2">
<Scorecard <Scorecard
title="time coding" title="time coding"
metric={ metric={

View file

@ -8,13 +8,13 @@ const PostListing = ({ posts, title, showAllButton }) => {
<div className="container mx-auto py-4 px-1 md:p-4 grow"> <div className="container mx-auto py-4 px-1 md:p-4 grow">
<div className="space-my-8"> <div className="space-my-8">
<section className="container"> <section className="container">
<h2 className="text-2xl font-semibold mb-4 block h2-home scanlined px-2"> <h2 className="text-3xl font-semibold mb-4 block h2-home">
{`${title}`} {`${title}`}
</h2> </h2>
{posts.map((post) => ( {posts.map((post) => (
<ul> <ul>
<li className="mb-4"> <li className="mb-4">
<div className="flex justify-between flex-col relative hover:bg-[#504945]"> <div className="flex justify-between flex-col relative hover:bg-[#504945] hover:rounded-2xl p-2">
<span className="overflow-hidden whitespace-nowrap text-muted-foreground shrink-0 condensed"> <span className="overflow-hidden whitespace-nowrap text-muted-foreground shrink-0 condensed">
{convertDate(post.date)} {convertDate(post.date)}
</span> </span>

View file

@ -17,31 +17,31 @@ body {
} }
.condensed { .condensed {
font-family: "Inter"; font-family: "IBM Plex Sans";
} }
figcaption { figcaption {
font-weight: 500; font-weight: 500;
font-family: "Inter"; font-family: "IBM Plex Sans";
} }
h1 { h1 {
color: var(--color-orange-light); color: var(--color-orange-light);
font-family: "Inter"; font-family: "IBM Plex Sans";
} }
h2 { h2 {
font-family: "Inter"; font-family: "IBM Plex Sans";
color: var(--color-green-light); color: var(--color-green-light);
} }
.h2-home { .h2-home {
font-family: "Inter"; font-family: "IBM Plex Sans";
font-weight: 600; font-weight: 600;
} }
h3 { h3 {
font-family: "Inter"; font-family: "IBM Plex Sans";
font-weight: 600 !important; font-weight: 600 !important;
} }
@ -73,6 +73,12 @@ code {
font-family: var(--font-monospaced); font-family: var(--font-monospaced);
} }
p,
li {
font-size: 1.125rem !important;
line-height: 1.8 !important;
}
p code { p code {
color: var(--foreground); color: var(--foreground);
background: #504945; background: #504945;

View file

@ -4,7 +4,6 @@ import { usePosts } from "@/hooks/usePosts"
import gruvboxComputer from "../images/gruvbox-computer.svg" import gruvboxComputer from "../images/gruvbox-computer.svg"
import EolasListing from "@/components/EolasListing" import EolasListing from "@/components/EolasListing"
import CodeStats from "../containers/CodeStats" import CodeStats from "../containers/CodeStats"
// import TodayILearned from "@/containers/TodayILearned"
const HomePage = () => { const HomePage = () => {
const { posts } = usePosts() const { posts } = usePosts()
@ -14,16 +13,17 @@ const HomePage = () => {
<div className="space-my-8"> <div className="space-my-8">
<section className="space-y-4"> <section className="space-y-4">
<div className="gap-6 flex flex-col items-center sm:flex-row"> <div className="gap-6 flex flex-col items-center sm:flex-row">
<div className="scanlined"> <div className="">
<img src={gruvboxComputer} className="md:w-80 w-50" /> <img
src={gruvboxComputer}
className="md:w-80 w-50 rounded-2xl"
/>
</div> </div>
<div> <div>
<h1 className="text-4xl font-bold py-3 text-center sm:text-left md:text-left"> <h1 className="text-5xl font-bold py-3 text-center sm:text-left md:text-left">
<div className="scanlined inline-block py-1 px-2"> <div className="">systems obscure</div>
systems obscure
</div>
</h1> </h1>
<p className="text-center sm:text-left md:text-left text-muted font-medium"> <p className="text-center sm:text-left md:text-left text-muted font-medium text-lg mt-1">
A wizard who goes to bed early. This is my technical scrapbook A wizard who goes to bed early. This is my technical scrapbook
and digital garden. and digital garden.
</p> </p>
@ -40,16 +40,16 @@ const HomePage = () => {
posts={posts.filter((post) => post.tags.includes("highlight"))} posts={posts.filter((post) => post.tags.includes("highlight"))}
/> />
<div className="container mx-auto md:p-4 py-4 px-1 grow"> <div className="container mx-auto md:p-4 py-4 px-1 grow mb-4">
<div className="space-my-8"> <div className="">
<section className="container"> <section className="container">
<h2 className="text-2xl font-semibold mb-4 text-[#d3869b]! h2-home scanlined px-2"> <h2 className="text-3xl font-semibold mb-4 text-[#d3869b]! h2-home">
{`projects`} {`projects`}
</h2> </h2>
<ul> <ul className="p-2">
<li className="pb-2"> <li className="pb-2">
<a <a
className="underline underline-offset-4 text-[18px] text-primary hover:text-primary/80 font-medium" className="underline underline-offset-4 text-primary hover:text-primary/80 font-medium text-xl"
href="https://eolas.systemsobscure.net" href="https://eolas.systemsobscure.net"
target="_blank" target="_blank"
> >

View file

@ -1,7 +1,7 @@
:root { :root {
--radius: 0.3rem; --radius: 0.3rem;
--background: #282828; --background: #282828;
--foreground: #ebdbb2; --foreground: #fbf1c7;
--sidebar: #3c3836; --sidebar: #3c3836;
--color-red-light: #fb4934; --color-red-light: #fb4934;
--color-orange-light: #fe8019; --color-orange-light: #fe8019;
@ -37,7 +37,7 @@
--sidebar-border: oklch(0.922 0 0); --sidebar-border: oklch(0.922 0 0);
--sidebar-ring: oklch(0.708 0 0); --sidebar-ring: oklch(0.708 0 0);
--font-monospaced: "Jetbrains Mono"; --font-monospaced: "Jetbrains Mono";
--font-sansserif: "Inter", sans-serif; --font-sansserif: "IBM Plex Sans", sans-serif;
} }
@theme inline { @theme inline {

View file

@ -17,17 +17,17 @@ const BlogTemplate = () => {
) : ( ) : (
<article className="prose prose-lg max-w-none"> <article className="prose prose-lg max-w-none">
<header className="mb-6 pb-4"> <header className="mb-6 pb-4">
<h1 className="text-4xl font-bold mb-4 leading-tight inline-block scanlined px-2"> <h1 className="text-5xl font-bold mb-4 inline-block">
{post?.title} {post?.title}
</h1> </h1>
<div className="flex flex-wrap align-center gap-4 text-[#928374] condensed font-medium"> <div className="flex flex-wrap align-center gap-4 text-[#928374] condensed font-medium">
<time datetime={convertDate(post?.date)} className="text-sm"> <time datetime={convertDate(post?.date)} className="">
{convertDate(post?.date)} {convertDate(post?.date)}
</time> </time>
<div className="flex flex-wrap gap-3 align-center"> <div className="flex flex-wrap gap-3 align-center">
{post?.tags?.map((tag, i) => ( {post?.tags?.map((tag, i) => (
<Link <Link
className="text-primary text-sm underline underline-offset-3 hover:text-[#689d6a]" className="text-primary underline underline-offset-3 hover:text-[#689d6a]"
key={i} key={i}
to={`/tags/${tag}`} to={`/tags/${tag}`}
> >

View file

@ -5,16 +5,16 @@ import { Link } from "react-router"
const Header = () => { const Header = () => {
return ( return (
<header className="md:py-6 pb-4"> <header className="md:py-6 pb-4">
<nav className="bg-sidebar container mx-auto justify-between flex gap-1"> <nav className="bg-sidebar container mx-auto justify-between flex gap-1 rounded-r-2xl">
<Link to="/"> <Link to="/">
<div className="scanlined"> <div className="">
<img src={gruvboxComputer} className="w-11" /> <img src={gruvboxComputer} className="w-12" />
</div> </div>
</Link> </Link>
<ul class="flex space-x-4 px-4 py-2 text-sm"> <ul class="flex space-x-4 px-4 py-2 text-sm">
<li class="flex flex-col items-center justify-center"> <li class="flex flex-col items-center justify-center">
<Link <Link
class="text-primary underline underline-offset-3 hover:text-[#689d6a] condensed font-semibold text-lg" class="text-primary hover:text-[#689d6a] condensed font-semibold text-xl"
to="/posts" to="/posts"
> >
posts posts
@ -22,7 +22,7 @@ const Header = () => {
</li> </li>
<li class="flex flex-col items-center justify-center"> <li class="flex flex-col items-center justify-center">
<Link <Link
class="text-primary underline underline-offset-3 hover:text-[#689d6a] condensed font-semibold text-lg" class="text-primary hover:text-[#689d6a] condensed font-semibold text-xl"
to="/about" to="/about"
> >
about about
@ -36,8 +36,8 @@ const Header = () => {
const Footer = () => { const Footer = () => {
return ( return (
<footer className="bg-sidebar container mx-auto px-4 mt-10 mb-8"> <footer className="bg-sidebar container mx-auto px-4 mt-10 mb-8 rounded-2xl p-2">
<nav> <nav className="">
<ul className="flex flex-row justify-start gap-4"> <ul className="flex flex-row justify-start gap-4">
<li className="flex flex-col items-center justify-center"> <li className="flex flex-col items-center justify-center">
<a <a