diff --git a/.gitignore b/.gitignore index 0b297d4..07bbc6f 100644 --- a/.gitignore +++ b/.gitignore @@ -12,3 +12,4 @@ node_modules/ vendor/ sync.sh +static/extra diff --git a/assets/components.css b/assets/components.css index 7ee1d41..72686e0 100644 --- a/assets/components.css +++ b/assets/components.css @@ -42,9 +42,9 @@ nav li a { } nav li.selected a { - background-color: var(--theme-foreground); + background-color: var(--theme-primary); color: var(--theme-background); - border-radius: var(--radius-sm); + border-radius: var(--radius-lg); } nav a { @@ -106,21 +106,33 @@ section::before { } } -section.typewriting a::after, +.typewriting a::after, #donation a::after, -#links a::after { +#links a::after, +#about a::after, +article a::after { display: inline-block; width: 0.9em; height: 0.9em; margin-left: var(--space-1); vertical-align: -0.1em; - content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23cac7ee' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath stroke='none' d='M0 0h24v24H0z' fill='none'/%3E%3Cpath d='M12 6h-6a2 2 0 0 0 -2 2v10a2 2 0 0 0 2 2h10a2 2 0 0 0 2 -2v-6' /%3E%3Cpath d='M11 13l9 -9' /%3E%3Cpath d='M15 4h5v5' /%3E%3C/svg%3E"); + content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23a7a0ff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath stroke='none' d='M0 0h24v24H0z' fill='none'/%3E%3Cpath d='M12 6h-6a2 2 0 0 0 -2 2v10a2 2 0 0 0 2 2h10a2 2 0 0 0 2 -2v-6' /%3E%3Cpath d='M11 13l9 -9' /%3E%3Cpath d='M15 4h5v5' /%3E%3C/svg%3E"); +} + +@media (prefers-color-scheme: light) { + .typewriting a::after, + #donation a::after, + #links a::after, + #about a::after, + article a::after { + content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236f65f2' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath stroke='none' d='M0 0h24v24H0z' fill='none'/%3E%3Cpath d='M12 6h-6a2 2 0 0 0 -2 2v10a2 2 0 0 0 2 2h10a2 2 0 0 0 2 -2v-6' /%3E%3Cpath d='M11 13l9 -9' /%3E%3Cpath d='M15 4h5v5' /%3E%3C/svg%3E"); + } } section.typewriting a, #donation a, #links a { - color: var(--theme-foreground); + color: var(--theme-primary); } header { diff --git a/assets/home.css b/assets/home.css index aa9f8a7..0f191c7 100644 --- a/assets/home.css +++ b/assets/home.css @@ -17,13 +17,31 @@ background-color: var(--theme-background-alt); border: 1px solid var(--theme-separator); padding: var(--space-3) var(--space-4); - margin-bottom: var(--space-3); + margin-bottom: var(--space-2); position: relative; overflow: hidden; - border-radius: var(--radius-md); + border-radius: var(--radius-lg); transition: all var(--transition-fast); } +.project-card::before { + overflow: hidden; + display: flex; + position: absolute; + left: 0; + top: -7rem; + content: " a[href="/reports"] { + color: var(--theme-foreground-alt); + font-size: 0.75em; + font-style: italic; +} + article header h1 { font-size: var(--font-size-xl); - margin: var(--space-3) 0; + margin-top: var(--space-5); + margin-bottom: var(--space-3); color: var(--theme-foreground); } @@ -132,7 +147,7 @@ article header .tag { padding: var(--space-1) var(--space-3); background-color: var(--theme-background-alt); border: 1px solid var(--theme-separator); - border-radius: 2px; + border-radius: var(--radius-lg); color: var(--theme-foreground-alt); } @@ -179,3 +194,19 @@ article footer { color: var(--theme-foreground-alt); font-size: var(--font-size-md); } + +#reports-header { + display: flex; + align-items: center; + gap: var(--space-3); +} + +#reports-header > a { + font-size: 1rem; + display: flex; + align-items: center; +} + +#reports-header > a > svg { + margin-left: var(--space-1); +} diff --git a/assets/styles.css b/assets/styles.css index 495a3c1..28ba747 100644 --- a/assets/styles.css +++ b/assets/styles.css @@ -1,3 +1,5 @@ +@import url(/fonts/iosevka-custom/import.css); + *, *::before, *::after { @@ -57,11 +59,16 @@ button, cursor: pointer; } -html, body { +html, +body { font-size: var(--font-size-base); } -html, body, pre, code, button { +html, +body, +pre, +code, +button { font-family: "Iosevka Custom Web", "Iosevka Custom", "Iosevka", monospace, sans-serif; line-height: 1.7; diff --git a/assets/theme.css b/assets/theme.css index 3e46289..b081566 100644 --- a/assets/theme.css +++ b/assets/theme.css @@ -1,5 +1,5 @@ /** - * Copyright (c) 2025 favewa + * Copyright (c) 2025 miwa * SPDX-License-Identifier: AGPL-3.0-or-later */ @@ -7,7 +7,8 @@ --theme-background: #121317; --theme-background-alt: #090a0d; --theme-foreground: #cac7ee; - --theme-foreground-alt: #a4a3bd; + --theme-primary: #9f99f0; + --theme-foreground-alt: #9593b9; --theme-foreground-bruh: #7d7d86; --theme-separator: #232833; @@ -71,6 +72,7 @@ --theme-foreground: #1d1d1f; --theme-foreground-alt: #515154; --theme-foreground-bruh: #86868b; - --theme-separator: #d2d2d7; + --theme-separator: #b9b9bf; + --theme-primary: #6f65f2; } } diff --git a/client.ts b/client.ts index 135ecb5..f4a6dd3 100644 --- a/client.ts +++ b/client.ts @@ -1,5 +1,5 @@ /** - * Copyright (c) 2025 favewa + * Copyright (c) 2025 miwa * SPDX-License-Identifier: AGPL-3.0-or-later */ diff --git a/components/Button.tsx b/components/Button.tsx index e42af56..d11e0d5 100644 --- a/components/Button.tsx +++ b/components/Button.tsx @@ -1,5 +1,5 @@ /** - * Copyright (c) 2025 favewa + * Copyright (c) 2025 miwa * SPDX-License-Identifier: AGPL-3.0-or-later */ diff --git a/components/Empty.tsx b/components/Empty.tsx index b7b41e4..c4e3dff 100644 --- a/components/Empty.tsx +++ b/components/Empty.tsx @@ -1,5 +1,5 @@ /** - * Copyright (c) 2025 favewa + * Copyright (c) 2025 miwa * SPDX-License-Identifier: AGPL-3.0-or-later */ diff --git a/components/Fm.tsx b/components/Fm.tsx index ad6f682..38548a1 100644 --- a/components/Fm.tsx +++ b/components/Fm.tsx @@ -1,5 +1,5 @@ /** - * Copyright (c) 2025 favewa + * Copyright (c) 2025 miwa * SPDX-License-Identifier: AGPL-3.0-or-later */ @@ -34,11 +34,13 @@ export function Fm() { ▷ ) - : (track.loved && ( - - ❤ - - ))} + : ( + track.loved && ( + + ❤ + + ) + )} diff --git a/components/Footer.tsx b/components/Footer.tsx new file mode 100644 index 0000000..71f3ae8 --- /dev/null +++ b/components/Footer.tsx @@ -0,0 +1,29 @@ +/** + * Copyright (c) 2025 miwa + * SPDX-License-Identifier: AGPL-3.0-or-later + */ + +export default function Footer() { + return ( + + ); +} diff --git a/components/Header.tsx b/components/Header.tsx index 72804a6..60e54d7 100644 --- a/components/Header.tsx +++ b/components/Header.tsx @@ -1,5 +1,5 @@ /** - * Copyright (c) 2025 favewa + * Copyright (c) 2025 miwa * SPDX-License-Identifier: AGPL-3.0-or-later */ @@ -7,10 +7,9 @@ export function Header(props: any) { return (

- ~ - favewa + ~miwa lívia - laura + clara

she/her ∘ free software advocate ∘ linguistics enthusiast ૮ ˶ᵔ ᵕ ᵔ˶ sა diff --git a/components/Links.tsx b/components/Links.tsx index c10e6b6..fafc9b9 100644 --- a/components/Links.tsx +++ b/components/Links.tsx @@ -1,23 +1,26 @@ /** - * Copyright (c) 2025 favewa + * Copyright (c) 2025 miwa * SPDX-License-Identifier: AGPL-3.0-or-later */ -export default function Links( - props: { selected: "home" | "reports" | "misc" }, -) { +export default function Links(props: { + selected: "home" | "about" | "reports" | "misc"; +}) { return ( ); diff --git a/components/ProjectCard.tsx b/components/ProjectCard.tsx index 2c8a7a7..0235360 100644 --- a/components/ProjectCard.tsx +++ b/components/ProjectCard.tsx @@ -1,5 +1,5 @@ /** - * Copyright (c) 2025 favewa + * Copyright (c) 2025 miwa * SPDX-License-Identifier: AGPL-3.0-or-later */ diff --git a/components/Reports.tsx b/components/Reports.tsx index 9318def..25242f7 100644 --- a/components/Reports.tsx +++ b/components/Reports.tsx @@ -1,9 +1,10 @@ /** - * Copyright (c) 2025 favewa + * Copyright (c) 2025 miwa * SPDX-License-Identifier: AGPL-3.0-or-later */ import { Report } from "../utils/atproto.ts"; +import { formatReadingTime } from "../utils/blog.ts"; export interface ReportsProps { reports: Report[]; @@ -13,7 +14,28 @@ export default function Reports({ reports }: ReportsProps) { return ( <>
-

$reports

+

+ $reports + + [rss + + + + + + ] + +

thoughts, ramblings, and occasional coherence

@@ -21,13 +43,17 @@ export default function Reports({ reports }: ReportsProps) { {reports.map((report) => (
  • - {report.createdAt} + + {report.createdAt} · {formatReadingTime(report.readingTime)} +

    {report.title}

    {report.excerpt}

    {report.tags && (
    {report.tags.map((tag) => ( - {tag} + + {tag} + ))}
    )} diff --git a/deno.json b/deno.json index d276cbb..495dde5 100644 --- a/deno.json +++ b/deno.json @@ -5,7 +5,8 @@ "dev": "vite", "build": "vite build", "start": "deno serve -A _fresh/server.js", - "update": "deno run -A -r jsr:@fresh/update ." + "update": "deno run -A -r jsr:@fresh/update .", + "rss": "deno run --allow-net --allow-write scripts/generate-rss.ts" }, "fmt": { "useTabs": true @@ -33,9 +34,9 @@ "@musicorum/lastfm": "npm:@musicorum/lastfm@^0.4.0", "fresh": "jsr:@fresh/core@^2.1.4", "preact": "npm:preact@^10.27.2", - "@preact/signals": "npm:@preact/signals@^2.4.0", + "@preact/signals": "npm:@preact/signals@^2.5.0", "@fresh/plugin-vite": "jsr:@fresh/plugin-vite@^1.0.7", - "vite": "npm:vite@^7.2.1" + "vite": "npm:vite@^7.2.2" }, "compilerOptions": { "lib": [ diff --git a/deno.lock b/deno.lock index b3279ff..6c5e176 100644 --- a/deno.lock +++ b/deno.lock @@ -30,15 +30,15 @@ "npm:@mjackson/node-fetch-server@0.7": "0.7.0", "npm:@musicorum/lastfm@0.4": "0.4.0", "npm:@opentelemetry/api@^1.9.0": "1.9.0", - "npm:@preact/signals@^2.2.1": "2.4.0_preact@10.27.2", - "npm:@preact/signals@^2.4.0": "2.4.0_preact@10.27.2", - "npm:@prefresh/vite@^2.4.8": "2.4.11_preact@10.27.2_vite@7.2.1__picomatch@4.0.3", + "npm:@preact/signals@^2.2.1": "2.5.0_preact@10.27.2", + "npm:@preact/signals@^2.5.0": "2.5.0_preact@10.27.2", + "npm:@prefresh/vite@^2.4.8": "2.4.11_preact@10.27.2_vite@7.2.2__picomatch@4.0.3", "npm:esbuild-wasm@~0.25.11": "0.25.12", "npm:esbuild@0.25.7": "0.25.7", "npm:preact-render-to-string@^6.6.3": "6.6.3_preact@10.27.2", "npm:preact@^10.27.0": "10.27.2", "npm:preact@^10.27.2": "10.27.2", - "npm:vite@^7.2.1": "7.2.1_picomatch@4.0.3" + "npm:vite@^7.2.2": "7.2.2_picomatch@4.0.3" }, "jsr": { "@deno/esbuild-plugin@1.2.0": { @@ -671,8 +671,8 @@ "@preact/signals-core@1.12.1": { "integrity": "sha512-BwbTXpj+9QutoZLQvbttRg5x3l5468qaV2kufh+51yha1c53ep5dY4kTuZR35+3pAZxpfQerGJiQqg34ZNZ6uA==" }, - "@preact/signals@2.4.0_preact@10.27.2": { - "integrity": "sha512-kVEih9Ty55O+6OKJ85beQJ0gaV++Xci2N2kaQc3LjSUtHKQqB47oMaW6OfwHwzWLRbYsms/326s2ITGiHL7paw==", + "@preact/signals@2.5.0_preact@10.27.2": { + "integrity": "sha512-+9KrYvCtnssF4Q7e5xdX08aERL2th4w8kkzPAgI3mSEu2FsVeI93hInS2ifwNIzpEw8+9+e5FPtR7di1WvZiWg==", "dependencies": [ "@preact/signals-core", "preact" @@ -681,8 +681,8 @@ "@prefresh/babel-plugin@0.5.2": { "integrity": "sha512-AOl4HG6dAxWkJ5ndPHBgBa49oo/9bOiJuRDKHLSTyH+Fd9x00shTXpdiTj1W41l6oQIwUOAgJeHMn4QwIDpHkA==" }, - "@prefresh/core@1.5.8_preact@10.27.2": { - "integrity": "sha512-T7HMpakS1iPVCFZvfDLMGyrWAcO3toUN9/RkJUqqoRr/vNhQrZgHjidfhq3awDzAQtw1emDWH8dsOeu0DWqtgA==", + "@prefresh/core@1.5.9_preact@10.27.2": { + "integrity": "sha512-IKBKCPaz34OFVC+adiQ2qaTF5qdztO2/4ZPf4KsRTgjKosWqxVXmEbxCiUydYZRY8GVie+DQlKzQr9gt6HQ+EQ==", "dependencies": [ "preact" ] @@ -690,7 +690,7 @@ "@prefresh/utils@1.2.1": { "integrity": "sha512-vq/sIuN5nYfYzvyayXI4C2QkprfNaHUQ9ZX+3xLD8nL3rWyzpxOm1+K7RtMbhd+66QcaISViK7amjnheQ/4WZw==" }, - "@prefresh/vite@2.4.11_preact@10.27.2_vite@7.2.1__picomatch@4.0.3": { + "@prefresh/vite@2.4.11_preact@10.27.2_vite@7.2.2__picomatch@4.0.3": { "integrity": "sha512-/XjURQqdRiCG3NpMmWqE9kJwrg9IchIOWHzulCfqg2sRe/8oQ1g5De7xrk9lbqPIQLn7ntBkKdqWXIj4E9YXyg==", "dependencies": [ "@babel/core", @@ -709,113 +709,113 @@ "picomatch@2.3.1" ] }, - "@rollup/rollup-android-arm-eabi@4.52.5": { - "integrity": "sha512-8c1vW4ocv3UOMp9K+gToY5zL2XiiVw3k7f1ksf4yO1FlDFQ1C2u72iACFnSOceJFsWskc2WZNqeRhFRPzv+wtQ==", + "@rollup/rollup-android-arm-eabi@4.53.2": { + "integrity": "sha512-yDPzwsgiFO26RJA4nZo8I+xqzh7sJTZIWQOxn+/XOdPE31lAvLIYCKqjV+lNH/vxE2L2iH3plKxDCRK6i+CwhA==", "os": ["android"], "cpu": ["arm"] }, - "@rollup/rollup-android-arm64@4.52.5": { - "integrity": "sha512-mQGfsIEFcu21mvqkEKKu2dYmtuSZOBMmAl5CFlPGLY94Vlcm+zWApK7F/eocsNzp8tKmbeBP8yXyAbx0XHsFNA==", + "@rollup/rollup-android-arm64@4.53.2": { + "integrity": "sha512-k8FontTxIE7b0/OGKeSN5B6j25EuppBcWM33Z19JoVT7UTXFSo3D9CdU39wGTeb29NO3XxpMNauh09B+Ibw+9g==", "os": ["android"], "cpu": ["arm64"] }, - "@rollup/rollup-darwin-arm64@4.52.5": { - "integrity": "sha512-takF3CR71mCAGA+v794QUZ0b6ZSrgJkArC+gUiG6LB6TQty9T0Mqh3m2ImRBOxS2IeYBo4lKWIieSvnEk2OQWA==", + "@rollup/rollup-darwin-arm64@4.53.2": { + "integrity": "sha512-A6s4gJpomNBtJ2yioj8bflM2oogDwzUiMl2yNJ2v9E7++sHrSrsQ29fOfn5DM/iCzpWcebNYEdXpaK4tr2RhfQ==", "os": ["darwin"], "cpu": ["arm64"] }, - "@rollup/rollup-darwin-x64@4.52.5": { - "integrity": "sha512-W901Pla8Ya95WpxDn//VF9K9u2JbocwV/v75TE0YIHNTbhqUTv9w4VuQ9MaWlNOkkEfFwkdNhXgcLqPSmHy0fA==", + "@rollup/rollup-darwin-x64@4.53.2": { + "integrity": "sha512-e6XqVmXlHrBlG56obu9gDRPW3O3hLxpwHpLsBJvuI8qqnsrtSZ9ERoWUXtPOkY8c78WghyPHZdmPhHLWNdAGEw==", "os": ["darwin"], "cpu": ["x64"] }, - "@rollup/rollup-freebsd-arm64@4.52.5": { - "integrity": "sha512-QofO7i7JycsYOWxe0GFqhLmF6l1TqBswJMvICnRUjqCx8b47MTo46W8AoeQwiokAx3zVryVnxtBMcGcnX12LvA==", + "@rollup/rollup-freebsd-arm64@4.53.2": { + "integrity": "sha512-v0E9lJW8VsrwPux5Qe5CwmH/CF/2mQs6xU1MF3nmUxmZUCHazCjLgYvToOk+YuuUqLQBio1qkkREhxhc656ViA==", "os": ["freebsd"], "cpu": ["arm64"] }, - "@rollup/rollup-freebsd-x64@4.52.5": { - "integrity": "sha512-jr21b/99ew8ujZubPo9skbrItHEIE50WdV86cdSoRkKtmWa+DDr6fu2c/xyRT0F/WazZpam6kk7IHBerSL7LDQ==", + "@rollup/rollup-freebsd-x64@4.53.2": { + "integrity": "sha512-ClAmAPx3ZCHtp6ysl4XEhWU69GUB1D+s7G9YjHGhIGCSrsg00nEGRRZHmINYxkdoJehde8VIsDC5t9C0gb6yqA==", "os": ["freebsd"], "cpu": ["x64"] }, - "@rollup/rollup-linux-arm-gnueabihf@4.52.5": { - "integrity": "sha512-PsNAbcyv9CcecAUagQefwX8fQn9LQ4nZkpDboBOttmyffnInRy8R8dSg6hxxl2Re5QhHBf6FYIDhIj5v982ATQ==", + "@rollup/rollup-linux-arm-gnueabihf@4.53.2": { + "integrity": "sha512-EPlb95nUsz6Dd9Qy13fI5kUPXNSljaG9FiJ4YUGU1O/Q77i5DYFW5KR8g1OzTcdZUqQQ1KdDqsTohdFVwCwjqg==", "os": ["linux"], "cpu": ["arm"] }, - "@rollup/rollup-linux-arm-musleabihf@4.52.5": { - "integrity": "sha512-Fw4tysRutyQc/wwkmcyoqFtJhh0u31K+Q6jYjeicsGJJ7bbEq8LwPWV/w0cnzOqR2m694/Af6hpFayLJZkG2VQ==", + "@rollup/rollup-linux-arm-musleabihf@4.53.2": { + "integrity": "sha512-BOmnVW+khAUX+YZvNfa0tGTEMVVEerOxN0pDk2E6N6DsEIa2Ctj48FOMfNDdrwinocKaC7YXUZ1pHlKpnkja/Q==", "os": ["linux"], "cpu": ["arm"] }, - "@rollup/rollup-linux-arm64-gnu@4.52.5": { - "integrity": "sha512-a+3wVnAYdQClOTlyapKmyI6BLPAFYs0JM8HRpgYZQO02rMR09ZcV9LbQB+NL6sljzG38869YqThrRnfPMCDtZg==", + "@rollup/rollup-linux-arm64-gnu@4.53.2": { + "integrity": "sha512-Xt2byDZ+6OVNuREgBXr4+CZDJtrVso5woFtpKdGPhpTPHcNG7D8YXeQzpNbFRxzTVqJf7kvPMCub/pcGUWgBjA==", "os": ["linux"], "cpu": ["arm64"] }, - "@rollup/rollup-linux-arm64-musl@4.52.5": { - "integrity": "sha512-AvttBOMwO9Pcuuf7m9PkC1PUIKsfaAJ4AYhy944qeTJgQOqJYJ9oVl2nYgY7Rk0mkbsuOpCAYSs6wLYB2Xiw0Q==", + "@rollup/rollup-linux-arm64-musl@4.53.2": { + "integrity": "sha512-+LdZSldy/I9N8+klim/Y1HsKbJ3BbInHav5qE9Iy77dtHC/pibw1SR/fXlWyAk0ThnpRKoODwnAuSjqxFRDHUQ==", "os": ["linux"], "cpu": ["arm64"] }, - "@rollup/rollup-linux-loong64-gnu@4.52.5": { - "integrity": "sha512-DkDk8pmXQV2wVrF6oq5tONK6UHLz/XcEVow4JTTerdeV1uqPeHxwcg7aFsfnSm9L+OO8WJsWotKM2JJPMWrQtA==", + "@rollup/rollup-linux-loong64-gnu@4.53.2": { + "integrity": "sha512-8ms8sjmyc1jWJS6WdNSA23rEfdjWB30LH8Wqj0Cqvv7qSHnvw6kgMMXRdop6hkmGPlyYBdRPkjJnj3KCUHV/uQ==", "os": ["linux"], "cpu": ["loong64"] }, - "@rollup/rollup-linux-ppc64-gnu@4.52.5": { - "integrity": "sha512-W/b9ZN/U9+hPQVvlGwjzi+Wy4xdoH2I8EjaCkMvzpI7wJUs8sWJ03Rq96jRnHkSrcHTpQe8h5Tg3ZzUPGauvAw==", + "@rollup/rollup-linux-ppc64-gnu@4.53.2": { + "integrity": "sha512-3HRQLUQbpBDMmzoxPJYd3W6vrVHOo2cVW8RUo87Xz0JPJcBLBr5kZ1pGcQAhdZgX9VV7NbGNipah1omKKe23/g==", "os": ["linux"], "cpu": ["ppc64"] }, - "@rollup/rollup-linux-riscv64-gnu@4.52.5": { - "integrity": "sha512-sjQLr9BW7R/ZiXnQiWPkErNfLMkkWIoCz7YMn27HldKsADEKa5WYdobaa1hmN6slu9oWQbB6/jFpJ+P2IkVrmw==", + "@rollup/rollup-linux-riscv64-gnu@4.53.2": { + "integrity": "sha512-fMjKi+ojnmIvhk34gZP94vjogXNNUKMEYs+EDaB/5TG/wUkoeua7p7VCHnE6T2Tx+iaghAqQX8teQzcvrYpaQA==", "os": ["linux"], "cpu": ["riscv64"] }, - "@rollup/rollup-linux-riscv64-musl@4.52.5": { - "integrity": "sha512-hq3jU/kGyjXWTvAh2awn8oHroCbrPm8JqM7RUpKjalIRWWXE01CQOf/tUNWNHjmbMHg/hmNCwc/Pz3k1T/j/Lg==", + "@rollup/rollup-linux-riscv64-musl@4.53.2": { + "integrity": "sha512-XuGFGU+VwUUV5kLvoAdi0Wz5Xbh2SrjIxCtZj6Wq8MDp4bflb/+ThZsVxokM7n0pcbkEr2h5/pzqzDYI7cCgLQ==", "os": ["linux"], "cpu": ["riscv64"] }, - "@rollup/rollup-linux-s390x-gnu@4.52.5": { - "integrity": "sha512-gn8kHOrku8D4NGHMK1Y7NA7INQTRdVOntt1OCYypZPRt6skGbddska44K8iocdpxHTMMNui5oH4elPH4QOLrFQ==", + "@rollup/rollup-linux-s390x-gnu@4.53.2": { + "integrity": "sha512-w6yjZF0P+NGzWR3AXWX9zc0DNEGdtvykB03uhonSHMRa+oWA6novflo2WaJr6JZakG2ucsyb+rvhrKac6NIy+w==", "os": ["linux"], "cpu": ["s390x"] }, - "@rollup/rollup-linux-x64-gnu@4.52.5": { - "integrity": "sha512-hXGLYpdhiNElzN770+H2nlx+jRog8TyynpTVzdlc6bndktjKWyZyiCsuDAlpd+j+W+WNqfcyAWz9HxxIGfZm1Q==", + "@rollup/rollup-linux-x64-gnu@4.53.2": { + "integrity": "sha512-yo8d6tdfdeBArzC7T/PnHd7OypfI9cbuZzPnzLJIyKYFhAQ8SvlkKtKBMbXDxe1h03Rcr7u++nFS7tqXz87Gtw==", "os": ["linux"], "cpu": ["x64"] }, - "@rollup/rollup-linux-x64-musl@4.52.5": { - "integrity": "sha512-arCGIcuNKjBoKAXD+y7XomR9gY6Mw7HnFBv5Rw7wQRvwYLR7gBAgV7Mb2QTyjXfTveBNFAtPt46/36vV9STLNg==", + "@rollup/rollup-linux-x64-musl@4.53.2": { + "integrity": "sha512-ah59c1YkCxKExPP8O9PwOvs+XRLKwh/mV+3YdKqQ5AMQ0r4M4ZDuOrpWkUaqO7fzAHdINzV9tEVu8vNw48z0lA==", "os": ["linux"], "cpu": ["x64"] }, - "@rollup/rollup-openharmony-arm64@4.52.5": { - "integrity": "sha512-QoFqB6+/9Rly/RiPjaomPLmR/13cgkIGfA40LHly9zcH1S0bN2HVFYk3a1eAyHQyjs3ZJYlXvIGtcCs5tko9Cw==", + "@rollup/rollup-openharmony-arm64@4.53.2": { + "integrity": "sha512-4VEd19Wmhr+Zy7hbUsFZ6YXEiP48hE//KPLCSVNY5RMGX2/7HZ+QkN55a3atM1C/BZCGIgqN+xrVgtdak2S9+A==", "os": ["openharmony"], "cpu": ["arm64"] }, - "@rollup/rollup-win32-arm64-msvc@4.52.5": { - "integrity": "sha512-w0cDWVR6MlTstla1cIfOGyl8+qb93FlAVutcor14Gf5Md5ap5ySfQ7R9S/NjNaMLSFdUnKGEasmVnu3lCMqB7w==", + "@rollup/rollup-win32-arm64-msvc@4.53.2": { + "integrity": "sha512-IlbHFYc/pQCgew/d5fslcy1KEaYVCJ44G8pajugd8VoOEI8ODhtb/j8XMhLpwHCMB3yk2J07ctup10gpw2nyMA==", "os": ["win32"], "cpu": ["arm64"] }, - "@rollup/rollup-win32-ia32-msvc@4.52.5": { - "integrity": "sha512-Aufdpzp7DpOTULJCuvzqcItSGDH73pF3ko/f+ckJhxQyHtp67rHw3HMNxoIdDMUITJESNE6a8uh4Lo4SLouOUg==", + "@rollup/rollup-win32-ia32-msvc@4.53.2": { + "integrity": "sha512-lNlPEGgdUfSzdCWU176ku/dQRnA7W+Gp8d+cWv73jYrb8uT7HTVVxq62DUYxjbaByuf1Yk0RIIAbDzp+CnOTFg==", "os": ["win32"], "cpu": ["ia32"] }, - "@rollup/rollup-win32-x64-gnu@4.52.5": { - "integrity": "sha512-UGBUGPFp1vkj6p8wCRraqNhqwX/4kNQPS57BCFc8wYh0g94iVIW33wJtQAx3G7vrjjNtRaxiMUylM0ktp/TRSQ==", + "@rollup/rollup-win32-x64-gnu@4.53.2": { + "integrity": "sha512-S6YojNVrHybQis2lYov1sd+uj7K0Q05NxHcGktuMMdIQ2VixGwAfbJ23NnlvvVV1bdpR2m5MsNBViHJKcA4ADw==", "os": ["win32"], "cpu": ["x64"] }, - "@rollup/rollup-win32-x64-msvc@4.52.5": { - "integrity": "sha512-TAcgQh2sSkykPRWLrdyy2AiceMckNf5loITqXxFI5VuQjS5tSuw3WlwdN8qv8vzjLAUTvYaH/mVjSFpbkFbpTg==", + "@rollup/rollup-win32-x64-msvc@4.53.2": { + "integrity": "sha512-k+/Rkcyx//P6fetPoLMb8pBeqJBNGx81uuf7iljX9++yNBVRDQgD04L+SVXmXmh5ZP4/WOp4mWF0kmi06PW2tA==", "os": ["win32"], "cpu": ["x64"] }, @@ -825,12 +825,12 @@ "await-lock@2.2.2": { "integrity": "sha512-aDczADvlvTGajTDjcjpJMqRkOF6Qdz3YbPZm/PyW6tKPkx2hlYBzxMhEywM/tU72HrVZjgl5VCdRuMlA7pZ8Gw==" }, - "baseline-browser-mapping@2.8.25": { - "integrity": "sha512-2NovHVesVF5TXefsGX1yzx1xgr7+m9JQenvz6FQY3qd+YXkKkYiv+vTCc7OriP9mcDZpTC5mAOYN4ocd29+erA==", + "baseline-browser-mapping@2.8.27": { + "integrity": "sha512-2CXFpkjVnY2FT+B6GrSYxzYf65BJWEqz5tIRHCvNsZZ2F3CmsCB37h8SpYgKG7y9C4YAeTipIPWG7EmFmhAeXA==", "bin": true }, - "browserslist@4.27.0": { - "integrity": "sha512-AXVQwdhot1eqLihwasPElhX2tAZiBjWdJ9i/Zcj2S6QYIjkx62OKSfnobkriB81C3l4w0rVy3Nt4jaTBltYEpw==", + "browserslist@4.28.0": { + "integrity": "sha512-tbydkR/CxfMwelN0vwdP/pLkDwyAASZ+VfWm4EOwlB6SWhx1sYnWLqo8N5j0rAzPfzfRaxt0mM/4wPU/Su84RQ==", "dependencies": [ "baseline-browser-mapping", "caniuse-lite", @@ -852,8 +852,8 @@ "ms" ] }, - "electron-to-chromium@1.5.246": { - "integrity": "sha512-CKp2enkTcw94o8p7P+nb3in3yILO7jAIoERSmkIhGazMuK2eLnPSVUH/dxUveGN8ulJJDjYUv0vV7y2e2AZ0nA==" + "electron-to-chromium@1.5.250": { + "integrity": "sha512-/5UMj9IiGDMOFBnN4i7/Ry5onJrAGSbOGo3s9FEKmwobGq6xw832ccET0CE3CkkMBZ8GJSlUIesZofpyurqDXw==" }, "esbuild-wasm@0.25.12": { "integrity": "sha512-rZqkjL3Y6FwLpSHzLnaEy8Ps6veCNo1kZa9EOfJvmWtBq5dJH4iVjfmOO6Mlkv9B0tt9WFPFmb/VxlgJOnueNg==", @@ -1010,8 +1010,8 @@ "preact@10.27.2": { "integrity": "sha512-5SYSgFKSyhCbk6SrXyMpqjb5+MQBgfvEKE/OC+PujcY34sOpqtr+0AZQtPYx5IA6VxynQ7rUPCtKzyovpj9Bpg==" }, - "rollup@4.52.5": { - "integrity": "sha512-3GuObel8h7Kqdjt0gxkEzaifHTqLVW56Y/bjN7PSQtkKr0w3V/QYSdt6QWYtd7A1xUtYQigtdUfgj1RvWVtorw==", + "rollup@4.53.2": { + "integrity": "sha512-MHngMYwGJVi6Fmnk6ISmnk7JAHRNF0UkuucA0CUW3N3a4KnONPEZz+vUanQP/ZC/iY1Qkf3bwPWzyY84wEks1g==", "dependencies": [ "@types/estree" ], @@ -1066,7 +1066,7 @@ "multiformats" ] }, - "update-browserslist-db@1.1.4_browserslist@4.27.0": { + "update-browserslist-db@1.1.4_browserslist@4.28.0": { "integrity": "sha512-q0SPT4xyU84saUX+tomz1WLkxUbuaJnR1xWt17M7fJtEJigJeWUNGUqrauFXsHnqev9y9JTRGwk13tFBuKby4A==", "dependencies": [ "browserslist", @@ -1075,8 +1075,8 @@ ], "bin": true }, - "vite@7.2.1_picomatch@4.0.3": { - "integrity": "sha512-qTl3VF7BvOupTR85Zc561sPEgxyUSNSvTQ9fit7DEMP7yPgvvIGm5Zfa1dOM+kOwWGNviK9uFM9ra77+OjK7lQ==", + "vite@7.2.2_picomatch@4.0.3": { + "integrity": "sha512-BxAKBWmIbrDgrokdGZH1IgkIk/5mMHDreLDmCJ0qpyJaAteP8NvMhkwr/ZCQNqNH97bw/dANTE9PDzqwJghfMQ==", "dependencies": [ "esbuild@0.25.12", "fdir", @@ -1530,9 +1530,9 @@ "jsr:@fresh/plugin-vite@^1.0.7", "npm:@atproto/api@0.18", "npm:@musicorum/lastfm@0.4", - "npm:@preact/signals@^2.4.0", + "npm:@preact/signals@^2.5.0", "npm:preact@^10.27.2", - "npm:vite@^7.2.1" + "npm:vite@^7.2.2" ] } } diff --git a/islands/Code.tsx b/islands/Code.tsx index d051708..b0e35c4 100644 --- a/islands/Code.tsx +++ b/islands/Code.tsx @@ -1,5 +1,5 @@ /** - * Copyright (c) 2025 favewa + * Copyright (c) 2025 miwa * SPDX-License-Identifier: AGPL-3.0-or-later */ diff --git a/islands/Meow.tsx b/islands/Meow.tsx index c70213d..45faa64 100644 --- a/islands/Meow.tsx +++ b/islands/Meow.tsx @@ -1,5 +1,5 @@ /** - * Copyright (c) 2025 favewa + * Copyright (c) 2025 miwa * SPDX-License-Identifier: AGPL-3.0-or-later */ @@ -10,12 +10,12 @@ export default function Meow() { id="muxiepuff" onClick={() => navigator.clipboard.writeText( - '
    acpi.at', + 'acpi.at', )} > acpi.at diff --git a/main.ts b/main.ts index b99cac7..b4082ea 100644 --- a/main.ts +++ b/main.ts @@ -1,5 +1,5 @@ /** - * Copyright (c) 2025 favewa + * Copyright (c) 2025 miwa * SPDX-License-Identifier: AGPL-3.0-or-later */ diff --git a/routes/_app.tsx b/routes/_app.tsx index 55707fc..d10def4 100644 --- a/routes/_app.tsx +++ b/routes/_app.tsx @@ -1,5 +1,5 @@ /** - * Copyright (c) 2025 favewa + * Copyright (c) 2025 miwa * SPDX-License-Identifier: AGPL-3.0-or-later */ diff --git a/routes/_error.tsx b/routes/_error.tsx index 57b84a3..a99d788 100644 --- a/routes/_error.tsx +++ b/routes/_error.tsx @@ -1,5 +1,5 @@ /** - * Copyright (c) 2025 favewa + * Copyright (c) 2025 miwa * SPDX-License-Identifier: AGPL-3.0-or-later */ diff --git a/routes/about.tsx b/routes/about.tsx new file mode 100644 index 0000000..472a920 --- /dev/null +++ b/routes/about.tsx @@ -0,0 +1,77 @@ +/** + * Copyright (c) 2025 miwa + * SPDX-License-Identifier: AGPL-3.0-or-later + */ + +import { Fm } from "@/components/Fm.tsx"; +import { Header } from "@/components/Header.tsx"; +import Links from "@/components/Links.tsx"; +import ProjectCard from "@/components/ProjectCard.tsx"; +import Code from "@/islands/Code.tsx"; +import Meow from "@/islands/Meow.tsx"; +import "@/assets/home.css"; +import Footer from "../components/Footer.tsx"; + +export default function About() { + return ( + <> + +
    +

    About

    +

    + I'm an aspiring electrical engineer with a keen interest in open + access to information and knowledge. My technical work centers on + functional programming, C99, and writing quirky TypeScript code that + explores its more obscure corners and unconventional patterns. I'm + drawn to atypical low-level technologies and have a particular + interest in the x86 and RISC-V ISAs. +

    +

    + In a more personal tone...{" "} + Hewwo! I'm Lívia, a 18-year-old girl from Brazil passionate about open + access to information, technology, linguistics, functional + programming, and pretty much anything that involves understanding + technology, human language, or philosophical frameworks. I hope you + find something interesting here, and don't hesitate to reach out if + you feel like it. :3 +

    +

    + When I'm not studying circuits or coding, it's likely that I'm either + exploring linguistics or listening to music. My tastes shift + constantly with my hyperfocus, ranging from indie, shoegaze, and J-Pop + to speedcore and various metal derivatives. I run a FreeBSD server + that hosts this site and various services, serving as my hands-on lab + for systems administration. ^-^ +

    +

    + Beyond quirky technology, I really{" "} + like linguistics and philosophy enthusiast. I'm also autistic n' ADHD, + so I might struggle with humour once in a while. I really like + befriending new people and growing as a person every single day!!! If + you've read this far, thanks for stopping by!{" "} +

    +
    +
    +

    languages

    +
      +
    • + brazilian portuguese (native) +
    • +
    • + «all over the place» english (C1) +
    • +
    • + latin american spanish (A2) +
    • +
    +
    +
    +

    trivia

    +
      +
    • there are no easter eggs up here. go away
    • +
    +
    +
    + + ); +} diff --git a/routes/index.tsx b/routes/index.tsx index 1ac27db..1345158 100644 --- a/routes/index.tsx +++ b/routes/index.tsx @@ -1,5 +1,5 @@ /** - * Copyright (c) 2025 favewa + * Copyright (c) 2025 miwa * SPDX-License-Identifier: AGPL-3.0-or-later */ @@ -10,6 +10,7 @@ import ProjectCard from "@/components/ProjectCard.tsx"; import Code from "@/islands/Code.tsx"; import Meow from "@/islands/Meow.tsx"; import "@/assets/home.css"; +import Footer from "../components/Footer.tsx"; export default function Home() { return ( @@ -17,16 +18,14 @@ export default function Home() {
    -

    About

    +

    Summary

    - Advocate for open access to information and knowledge and aspiring - electrical engineer with complementary interests in systems - programming and linguistics. -

    -

    - On the side, I maintain a modest FreeBSD server where I self-host this - website and various services. This is nothing particularly impressive, - just a growing curiosity about systems administration. + I'm an aspiring electrical engineer with a keen interest in open + access to information and knowledge. My technical work centers on + functional programming, C99, and writing quirky TypeScript code that + explores its more obscure corners and unconventional patterns. I'm + drawn to atypical low-level technologies and have a particular + interest in the x86 and RISC-V ISAs. Read more

  • - - @favewa on Telegram + + @lauwawa on Telegram
  • @@ -71,8 +70,8 @@ export default function Home() {

    Code