diff --git a/.gitignore b/.gitignore index 07bbc6f..0b297d4 100644 --- a/.gitignore +++ b/.gitignore @@ -12,4 +12,3 @@ node_modules/ vendor/ sync.sh -static/extra diff --git a/assets/components.css b/assets/components.css index 72686e0..7ee1d41 100644 --- a/assets/components.css +++ b/assets/components.css @@ -42,9 +42,9 @@ nav li a { } nav li.selected a { - background-color: var(--theme-primary); + background-color: var(--theme-foreground); color: var(--theme-background); - border-radius: var(--radius-lg); + border-radius: var(--radius-sm); } nav a { @@ -106,33 +106,21 @@ section::before { } } -.typewriting a::after, +section.typewriting a::after, #donation a::after, -#links a::after, -#about a::after, -article a::after { +#links 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='%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"); - } + 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"); } section.typewriting a, #donation a, #links a { - color: var(--theme-primary); + color: var(--theme-foreground); } header { diff --git a/assets/home.css b/assets/home.css index 0f191c7..aa9f8a7 100644 --- a/assets/home.css +++ b/assets/home.css @@ -17,31 +17,13 @@ background-color: var(--theme-background-alt); border: 1px solid var(--theme-separator); padding: var(--space-3) var(--space-4); - margin-bottom: var(--space-2); + margin-bottom: var(--space-3); position: relative; overflow: hidden; - border-radius: var(--radius-lg); + border-radius: var(--radius-md); 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-top: var(--space-5); - margin-bottom: var(--space-3); + margin: var(--space-3) 0; color: var(--theme-foreground); } @@ -147,7 +132,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: var(--radius-lg); + border-radius: 2px; color: var(--theme-foreground-alt); } @@ -194,19 +179,3 @@ 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 28ba747..495a3c1 100644 --- a/assets/styles.css +++ b/assets/styles.css @@ -1,5 +1,3 @@ -@import url(/fonts/iosevka-custom/import.css); - *, *::before, *::after { @@ -59,16 +57,11 @@ 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 b081566..3e46289 100644 --- a/assets/theme.css +++ b/assets/theme.css @@ -1,5 +1,5 @@ /** - * Copyright (c) 2025 miwa + * Copyright (c) 2025 favewa * SPDX-License-Identifier: AGPL-3.0-or-later */ @@ -7,8 +7,7 @@ --theme-background: #121317; --theme-background-alt: #090a0d; --theme-foreground: #cac7ee; - --theme-primary: #9f99f0; - --theme-foreground-alt: #9593b9; + --theme-foreground-alt: #a4a3bd; --theme-foreground-bruh: #7d7d86; --theme-separator: #232833; @@ -72,7 +71,6 @@ --theme-foreground: #1d1d1f; --theme-foreground-alt: #515154; --theme-foreground-bruh: #86868b; - --theme-separator: #b9b9bf; - --theme-primary: #6f65f2; + --theme-separator: #d2d2d7; } } diff --git a/client.ts b/client.ts index f4a6dd3..135ecb5 100644 --- a/client.ts +++ b/client.ts @@ -1,5 +1,5 @@ /** - * Copyright (c) 2025 miwa + * Copyright (c) 2025 favewa * SPDX-License-Identifier: AGPL-3.0-or-later */ diff --git a/components/Button.tsx b/components/Button.tsx index d11e0d5..e42af56 100644 --- a/components/Button.tsx +++ b/components/Button.tsx @@ -1,5 +1,5 @@ /** - * Copyright (c) 2025 miwa + * Copyright (c) 2025 favewa * SPDX-License-Identifier: AGPL-3.0-or-later */ diff --git a/components/Empty.tsx b/components/Empty.tsx index c4e3dff..b7b41e4 100644 --- a/components/Empty.tsx +++ b/components/Empty.tsx @@ -1,5 +1,5 @@ /** - * Copyright (c) 2025 miwa + * Copyright (c) 2025 favewa * SPDX-License-Identifier: AGPL-3.0-or-later */ diff --git a/components/Fm.tsx b/components/Fm.tsx index 38548a1..ad6f682 100644 --- a/components/Fm.tsx +++ b/components/Fm.tsx @@ -1,5 +1,5 @@ /** - * Copyright (c) 2025 miwa + * Copyright (c) 2025 favewa * SPDX-License-Identifier: AGPL-3.0-or-later */ @@ -34,13 +34,11 @@ export function Fm() { ▷ ) - : ( - track.loved && ( - - ❤ - - ) - )} + : (track.loved && ( + + ❤ + + ))} diff --git a/components/Footer.tsx b/components/Footer.tsx deleted file mode 100644 index 71f3ae8..0000000 --- a/components/Footer.tsx +++ /dev/null @@ -1,29 +0,0 @@ -/** - * 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 60e54d7..72804a6 100644 --- a/components/Header.tsx +++ b/components/Header.tsx @@ -1,5 +1,5 @@ /** - * Copyright (c) 2025 miwa + * Copyright (c) 2025 favewa * SPDX-License-Identifier: AGPL-3.0-or-later */ @@ -7,9 +7,10 @@ export function Header(props: any) { return (

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

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

- $reports - - [rss - - - - - - ] - -

+

$reports

thoughts, ramblings, and occasional coherence

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

    {report.title}

    {report.excerpt}

    {report.tags && (
    {report.tags.map((tag) => ( - - {tag} - + {tag} ))}
    )} diff --git a/deno.json b/deno.json index 495dde5..d276cbb 100644 --- a/deno.json +++ b/deno.json @@ -5,8 +5,7 @@ "dev": "vite", "build": "vite build", "start": "deno serve -A _fresh/server.js", - "update": "deno run -A -r jsr:@fresh/update .", - "rss": "deno run --allow-net --allow-write scripts/generate-rss.ts" + "update": "deno run -A -r jsr:@fresh/update ." }, "fmt": { "useTabs": true @@ -34,9 +33,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.5.0", + "@preact/signals": "npm:@preact/signals@^2.4.0", "@fresh/plugin-vite": "jsr:@fresh/plugin-vite@^1.0.7", - "vite": "npm:vite@^7.2.2" + "vite": "npm:vite@^7.2.1" }, "compilerOptions": { "lib": [ diff --git a/deno.lock b/deno.lock index 6c5e176..b3279ff 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.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:@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: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.2": "7.2.2_picomatch@4.0.3" + "npm:vite@^7.2.1": "7.2.1_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.5.0_preact@10.27.2": { - "integrity": "sha512-+9KrYvCtnssF4Q7e5xdX08aERL2th4w8kkzPAgI3mSEu2FsVeI93hInS2ifwNIzpEw8+9+e5FPtR7di1WvZiWg==", + "@preact/signals@2.4.0_preact@10.27.2": { + "integrity": "sha512-kVEih9Ty55O+6OKJ85beQJ0gaV++Xci2N2kaQc3LjSUtHKQqB47oMaW6OfwHwzWLRbYsms/326s2ITGiHL7paw==", "dependencies": [ "@preact/signals-core", "preact" @@ -681,8 +681,8 @@ "@prefresh/babel-plugin@0.5.2": { "integrity": "sha512-AOl4HG6dAxWkJ5ndPHBgBa49oo/9bOiJuRDKHLSTyH+Fd9x00shTXpdiTj1W41l6oQIwUOAgJeHMn4QwIDpHkA==" }, - "@prefresh/core@1.5.9_preact@10.27.2": { - "integrity": "sha512-IKBKCPaz34OFVC+adiQ2qaTF5qdztO2/4ZPf4KsRTgjKosWqxVXmEbxCiUydYZRY8GVie+DQlKzQr9gt6HQ+EQ==", + "@prefresh/core@1.5.8_preact@10.27.2": { + "integrity": "sha512-T7HMpakS1iPVCFZvfDLMGyrWAcO3toUN9/RkJUqqoRr/vNhQrZgHjidfhq3awDzAQtw1emDWH8dsOeu0DWqtgA==", "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.2__picomatch@4.0.3": { + "@prefresh/vite@2.4.11_preact@10.27.2_vite@7.2.1__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.53.2": { - "integrity": "sha512-yDPzwsgiFO26RJA4nZo8I+xqzh7sJTZIWQOxn+/XOdPE31lAvLIYCKqjV+lNH/vxE2L2iH3plKxDCRK6i+CwhA==", + "@rollup/rollup-android-arm-eabi@4.52.5": { + "integrity": "sha512-8c1vW4ocv3UOMp9K+gToY5zL2XiiVw3k7f1ksf4yO1FlDFQ1C2u72iACFnSOceJFsWskc2WZNqeRhFRPzv+wtQ==", "os": ["android"], "cpu": ["arm"] }, - "@rollup/rollup-android-arm64@4.53.2": { - "integrity": "sha512-k8FontTxIE7b0/OGKeSN5B6j25EuppBcWM33Z19JoVT7UTXFSo3D9CdU39wGTeb29NO3XxpMNauh09B+Ibw+9g==", + "@rollup/rollup-android-arm64@4.52.5": { + "integrity": "sha512-mQGfsIEFcu21mvqkEKKu2dYmtuSZOBMmAl5CFlPGLY94Vlcm+zWApK7F/eocsNzp8tKmbeBP8yXyAbx0XHsFNA==", "os": ["android"], "cpu": ["arm64"] }, - "@rollup/rollup-darwin-arm64@4.53.2": { - "integrity": "sha512-A6s4gJpomNBtJ2yioj8bflM2oogDwzUiMl2yNJ2v9E7++sHrSrsQ29fOfn5DM/iCzpWcebNYEdXpaK4tr2RhfQ==", + "@rollup/rollup-darwin-arm64@4.52.5": { + "integrity": "sha512-takF3CR71mCAGA+v794QUZ0b6ZSrgJkArC+gUiG6LB6TQty9T0Mqh3m2ImRBOxS2IeYBo4lKWIieSvnEk2OQWA==", "os": ["darwin"], "cpu": ["arm64"] }, - "@rollup/rollup-darwin-x64@4.53.2": { - "integrity": "sha512-e6XqVmXlHrBlG56obu9gDRPW3O3hLxpwHpLsBJvuI8qqnsrtSZ9ERoWUXtPOkY8c78WghyPHZdmPhHLWNdAGEw==", + "@rollup/rollup-darwin-x64@4.52.5": { + "integrity": "sha512-W901Pla8Ya95WpxDn//VF9K9u2JbocwV/v75TE0YIHNTbhqUTv9w4VuQ9MaWlNOkkEfFwkdNhXgcLqPSmHy0fA==", "os": ["darwin"], "cpu": ["x64"] }, - "@rollup/rollup-freebsd-arm64@4.53.2": { - "integrity": "sha512-v0E9lJW8VsrwPux5Qe5CwmH/CF/2mQs6xU1MF3nmUxmZUCHazCjLgYvToOk+YuuUqLQBio1qkkREhxhc656ViA==", + "@rollup/rollup-freebsd-arm64@4.52.5": { + "integrity": "sha512-QofO7i7JycsYOWxe0GFqhLmF6l1TqBswJMvICnRUjqCx8b47MTo46W8AoeQwiokAx3zVryVnxtBMcGcnX12LvA==", "os": ["freebsd"], "cpu": ["arm64"] }, - "@rollup/rollup-freebsd-x64@4.53.2": { - "integrity": "sha512-ClAmAPx3ZCHtp6ysl4XEhWU69GUB1D+s7G9YjHGhIGCSrsg00nEGRRZHmINYxkdoJehde8VIsDC5t9C0gb6yqA==", + "@rollup/rollup-freebsd-x64@4.52.5": { + "integrity": "sha512-jr21b/99ew8ujZubPo9skbrItHEIE50WdV86cdSoRkKtmWa+DDr6fu2c/xyRT0F/WazZpam6kk7IHBerSL7LDQ==", "os": ["freebsd"], "cpu": ["x64"] }, - "@rollup/rollup-linux-arm-gnueabihf@4.53.2": { - "integrity": "sha512-EPlb95nUsz6Dd9Qy13fI5kUPXNSljaG9FiJ4YUGU1O/Q77i5DYFW5KR8g1OzTcdZUqQQ1KdDqsTohdFVwCwjqg==", + "@rollup/rollup-linux-arm-gnueabihf@4.52.5": { + "integrity": "sha512-PsNAbcyv9CcecAUagQefwX8fQn9LQ4nZkpDboBOttmyffnInRy8R8dSg6hxxl2Re5QhHBf6FYIDhIj5v982ATQ==", "os": ["linux"], "cpu": ["arm"] }, - "@rollup/rollup-linux-arm-musleabihf@4.53.2": { - "integrity": "sha512-BOmnVW+khAUX+YZvNfa0tGTEMVVEerOxN0pDk2E6N6DsEIa2Ctj48FOMfNDdrwinocKaC7YXUZ1pHlKpnkja/Q==", + "@rollup/rollup-linux-arm-musleabihf@4.52.5": { + "integrity": "sha512-Fw4tysRutyQc/wwkmcyoqFtJhh0u31K+Q6jYjeicsGJJ7bbEq8LwPWV/w0cnzOqR2m694/Af6hpFayLJZkG2VQ==", "os": ["linux"], "cpu": ["arm"] }, - "@rollup/rollup-linux-arm64-gnu@4.53.2": { - "integrity": "sha512-Xt2byDZ+6OVNuREgBXr4+CZDJtrVso5woFtpKdGPhpTPHcNG7D8YXeQzpNbFRxzTVqJf7kvPMCub/pcGUWgBjA==", + "@rollup/rollup-linux-arm64-gnu@4.52.5": { + "integrity": "sha512-a+3wVnAYdQClOTlyapKmyI6BLPAFYs0JM8HRpgYZQO02rMR09ZcV9LbQB+NL6sljzG38869YqThrRnfPMCDtZg==", "os": ["linux"], "cpu": ["arm64"] }, - "@rollup/rollup-linux-arm64-musl@4.53.2": { - "integrity": "sha512-+LdZSldy/I9N8+klim/Y1HsKbJ3BbInHav5qE9Iy77dtHC/pibw1SR/fXlWyAk0ThnpRKoODwnAuSjqxFRDHUQ==", + "@rollup/rollup-linux-arm64-musl@4.52.5": { + "integrity": "sha512-AvttBOMwO9Pcuuf7m9PkC1PUIKsfaAJ4AYhy944qeTJgQOqJYJ9oVl2nYgY7Rk0mkbsuOpCAYSs6wLYB2Xiw0Q==", "os": ["linux"], "cpu": ["arm64"] }, - "@rollup/rollup-linux-loong64-gnu@4.53.2": { - "integrity": "sha512-8ms8sjmyc1jWJS6WdNSA23rEfdjWB30LH8Wqj0Cqvv7qSHnvw6kgMMXRdop6hkmGPlyYBdRPkjJnj3KCUHV/uQ==", + "@rollup/rollup-linux-loong64-gnu@4.52.5": { + "integrity": "sha512-DkDk8pmXQV2wVrF6oq5tONK6UHLz/XcEVow4JTTerdeV1uqPeHxwcg7aFsfnSm9L+OO8WJsWotKM2JJPMWrQtA==", "os": ["linux"], "cpu": ["loong64"] }, - "@rollup/rollup-linux-ppc64-gnu@4.53.2": { - "integrity": "sha512-3HRQLUQbpBDMmzoxPJYd3W6vrVHOo2cVW8RUo87Xz0JPJcBLBr5kZ1pGcQAhdZgX9VV7NbGNipah1omKKe23/g==", + "@rollup/rollup-linux-ppc64-gnu@4.52.5": { + "integrity": "sha512-W/b9ZN/U9+hPQVvlGwjzi+Wy4xdoH2I8EjaCkMvzpI7wJUs8sWJ03Rq96jRnHkSrcHTpQe8h5Tg3ZzUPGauvAw==", "os": ["linux"], "cpu": ["ppc64"] }, - "@rollup/rollup-linux-riscv64-gnu@4.53.2": { - "integrity": "sha512-fMjKi+ojnmIvhk34gZP94vjogXNNUKMEYs+EDaB/5TG/wUkoeua7p7VCHnE6T2Tx+iaghAqQX8teQzcvrYpaQA==", + "@rollup/rollup-linux-riscv64-gnu@4.52.5": { + "integrity": "sha512-sjQLr9BW7R/ZiXnQiWPkErNfLMkkWIoCz7YMn27HldKsADEKa5WYdobaa1hmN6slu9oWQbB6/jFpJ+P2IkVrmw==", "os": ["linux"], "cpu": ["riscv64"] }, - "@rollup/rollup-linux-riscv64-musl@4.53.2": { - "integrity": "sha512-XuGFGU+VwUUV5kLvoAdi0Wz5Xbh2SrjIxCtZj6Wq8MDp4bflb/+ThZsVxokM7n0pcbkEr2h5/pzqzDYI7cCgLQ==", + "@rollup/rollup-linux-riscv64-musl@4.52.5": { + "integrity": "sha512-hq3jU/kGyjXWTvAh2awn8oHroCbrPm8JqM7RUpKjalIRWWXE01CQOf/tUNWNHjmbMHg/hmNCwc/Pz3k1T/j/Lg==", "os": ["linux"], "cpu": ["riscv64"] }, - "@rollup/rollup-linux-s390x-gnu@4.53.2": { - "integrity": "sha512-w6yjZF0P+NGzWR3AXWX9zc0DNEGdtvykB03uhonSHMRa+oWA6novflo2WaJr6JZakG2ucsyb+rvhrKac6NIy+w==", + "@rollup/rollup-linux-s390x-gnu@4.52.5": { + "integrity": "sha512-gn8kHOrku8D4NGHMK1Y7NA7INQTRdVOntt1OCYypZPRt6skGbddska44K8iocdpxHTMMNui5oH4elPH4QOLrFQ==", "os": ["linux"], "cpu": ["s390x"] }, - "@rollup/rollup-linux-x64-gnu@4.53.2": { - "integrity": "sha512-yo8d6tdfdeBArzC7T/PnHd7OypfI9cbuZzPnzLJIyKYFhAQ8SvlkKtKBMbXDxe1h03Rcr7u++nFS7tqXz87Gtw==", + "@rollup/rollup-linux-x64-gnu@4.52.5": { + "integrity": "sha512-hXGLYpdhiNElzN770+H2nlx+jRog8TyynpTVzdlc6bndktjKWyZyiCsuDAlpd+j+W+WNqfcyAWz9HxxIGfZm1Q==", "os": ["linux"], "cpu": ["x64"] }, - "@rollup/rollup-linux-x64-musl@4.53.2": { - "integrity": "sha512-ah59c1YkCxKExPP8O9PwOvs+XRLKwh/mV+3YdKqQ5AMQ0r4M4ZDuOrpWkUaqO7fzAHdINzV9tEVu8vNw48z0lA==", + "@rollup/rollup-linux-x64-musl@4.52.5": { + "integrity": "sha512-arCGIcuNKjBoKAXD+y7XomR9gY6Mw7HnFBv5Rw7wQRvwYLR7gBAgV7Mb2QTyjXfTveBNFAtPt46/36vV9STLNg==", "os": ["linux"], "cpu": ["x64"] }, - "@rollup/rollup-openharmony-arm64@4.53.2": { - "integrity": "sha512-4VEd19Wmhr+Zy7hbUsFZ6YXEiP48hE//KPLCSVNY5RMGX2/7HZ+QkN55a3atM1C/BZCGIgqN+xrVgtdak2S9+A==", + "@rollup/rollup-openharmony-arm64@4.52.5": { + "integrity": "sha512-QoFqB6+/9Rly/RiPjaomPLmR/13cgkIGfA40LHly9zcH1S0bN2HVFYk3a1eAyHQyjs3ZJYlXvIGtcCs5tko9Cw==", "os": ["openharmony"], "cpu": ["arm64"] }, - "@rollup/rollup-win32-arm64-msvc@4.53.2": { - "integrity": "sha512-IlbHFYc/pQCgew/d5fslcy1KEaYVCJ44G8pajugd8VoOEI8ODhtb/j8XMhLpwHCMB3yk2J07ctup10gpw2nyMA==", + "@rollup/rollup-win32-arm64-msvc@4.52.5": { + "integrity": "sha512-w0cDWVR6MlTstla1cIfOGyl8+qb93FlAVutcor14Gf5Md5ap5ySfQ7R9S/NjNaMLSFdUnKGEasmVnu3lCMqB7w==", "os": ["win32"], "cpu": ["arm64"] }, - "@rollup/rollup-win32-ia32-msvc@4.53.2": { - "integrity": "sha512-lNlPEGgdUfSzdCWU176ku/dQRnA7W+Gp8d+cWv73jYrb8uT7HTVVxq62DUYxjbaByuf1Yk0RIIAbDzp+CnOTFg==", + "@rollup/rollup-win32-ia32-msvc@4.52.5": { + "integrity": "sha512-Aufdpzp7DpOTULJCuvzqcItSGDH73pF3ko/f+ckJhxQyHtp67rHw3HMNxoIdDMUITJESNE6a8uh4Lo4SLouOUg==", "os": ["win32"], "cpu": ["ia32"] }, - "@rollup/rollup-win32-x64-gnu@4.53.2": { - "integrity": "sha512-S6YojNVrHybQis2lYov1sd+uj7K0Q05NxHcGktuMMdIQ2VixGwAfbJ23NnlvvVV1bdpR2m5MsNBViHJKcA4ADw==", + "@rollup/rollup-win32-x64-gnu@4.52.5": { + "integrity": "sha512-UGBUGPFp1vkj6p8wCRraqNhqwX/4kNQPS57BCFc8wYh0g94iVIW33wJtQAx3G7vrjjNtRaxiMUylM0ktp/TRSQ==", "os": ["win32"], "cpu": ["x64"] }, - "@rollup/rollup-win32-x64-msvc@4.53.2": { - "integrity": "sha512-k+/Rkcyx//P6fetPoLMb8pBeqJBNGx81uuf7iljX9++yNBVRDQgD04L+SVXmXmh5ZP4/WOp4mWF0kmi06PW2tA==", + "@rollup/rollup-win32-x64-msvc@4.52.5": { + "integrity": "sha512-TAcgQh2sSkykPRWLrdyy2AiceMckNf5loITqXxFI5VuQjS5tSuw3WlwdN8qv8vzjLAUTvYaH/mVjSFpbkFbpTg==", "os": ["win32"], "cpu": ["x64"] }, @@ -825,12 +825,12 @@ "await-lock@2.2.2": { "integrity": "sha512-aDczADvlvTGajTDjcjpJMqRkOF6Qdz3YbPZm/PyW6tKPkx2hlYBzxMhEywM/tU72HrVZjgl5VCdRuMlA7pZ8Gw==" }, - "baseline-browser-mapping@2.8.27": { - "integrity": "sha512-2CXFpkjVnY2FT+B6GrSYxzYf65BJWEqz5tIRHCvNsZZ2F3CmsCB37h8SpYgKG7y9C4YAeTipIPWG7EmFmhAeXA==", + "baseline-browser-mapping@2.8.25": { + "integrity": "sha512-2NovHVesVF5TXefsGX1yzx1xgr7+m9JQenvz6FQY3qd+YXkKkYiv+vTCc7OriP9mcDZpTC5mAOYN4ocd29+erA==", "bin": true }, - "browserslist@4.28.0": { - "integrity": "sha512-tbydkR/CxfMwelN0vwdP/pLkDwyAASZ+VfWm4EOwlB6SWhx1sYnWLqo8N5j0rAzPfzfRaxt0mM/4wPU/Su84RQ==", + "browserslist@4.27.0": { + "integrity": "sha512-AXVQwdhot1eqLihwasPElhX2tAZiBjWdJ9i/Zcj2S6QYIjkx62OKSfnobkriB81C3l4w0rVy3Nt4jaTBltYEpw==", "dependencies": [ "baseline-browser-mapping", "caniuse-lite", @@ -852,8 +852,8 @@ "ms" ] }, - "electron-to-chromium@1.5.250": { - "integrity": "sha512-/5UMj9IiGDMOFBnN4i7/Ry5onJrAGSbOGo3s9FEKmwobGq6xw832ccET0CE3CkkMBZ8GJSlUIesZofpyurqDXw==" + "electron-to-chromium@1.5.246": { + "integrity": "sha512-CKp2enkTcw94o8p7P+nb3in3yILO7jAIoERSmkIhGazMuK2eLnPSVUH/dxUveGN8ulJJDjYUv0vV7y2e2AZ0nA==" }, "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.53.2": { - "integrity": "sha512-MHngMYwGJVi6Fmnk6ISmnk7JAHRNF0UkuucA0CUW3N3a4KnONPEZz+vUanQP/ZC/iY1Qkf3bwPWzyY84wEks1g==", + "rollup@4.52.5": { + "integrity": "sha512-3GuObel8h7Kqdjt0gxkEzaifHTqLVW56Y/bjN7PSQtkKr0w3V/QYSdt6QWYtd7A1xUtYQigtdUfgj1RvWVtorw==", "dependencies": [ "@types/estree" ], @@ -1066,7 +1066,7 @@ "multiformats" ] }, - "update-browserslist-db@1.1.4_browserslist@4.28.0": { + "update-browserslist-db@1.1.4_browserslist@4.27.0": { "integrity": "sha512-q0SPT4xyU84saUX+tomz1WLkxUbuaJnR1xWt17M7fJtEJigJeWUNGUqrauFXsHnqev9y9JTRGwk13tFBuKby4A==", "dependencies": [ "browserslist", @@ -1075,8 +1075,8 @@ ], "bin": true }, - "vite@7.2.2_picomatch@4.0.3": { - "integrity": "sha512-BxAKBWmIbrDgrokdGZH1IgkIk/5mMHDreLDmCJ0qpyJaAteP8NvMhkwr/ZCQNqNH97bw/dANTE9PDzqwJghfMQ==", + "vite@7.2.1_picomatch@4.0.3": { + "integrity": "sha512-qTl3VF7BvOupTR85Zc561sPEgxyUSNSvTQ9fit7DEMP7yPgvvIGm5Zfa1dOM+kOwWGNviK9uFM9ra77+OjK7lQ==", "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.5.0", + "npm:@preact/signals@^2.4.0", "npm:preact@^10.27.2", - "npm:vite@^7.2.2" + "npm:vite@^7.2.1" ] } } diff --git a/islands/Code.tsx b/islands/Code.tsx index b0e35c4..d051708 100644 --- a/islands/Code.tsx +++ b/islands/Code.tsx @@ -1,5 +1,5 @@ /** - * Copyright (c) 2025 miwa + * Copyright (c) 2025 favewa * SPDX-License-Identifier: AGPL-3.0-or-later */ diff --git a/islands/Meow.tsx b/islands/Meow.tsx index 45faa64..c70213d 100644 --- a/islands/Meow.tsx +++ b/islands/Meow.tsx @@ -1,5 +1,5 @@ /** - * Copyright (c) 2025 miwa + * Copyright (c) 2025 favewa * 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 b4082ea..b99cac7 100644 --- a/main.ts +++ b/main.ts @@ -1,5 +1,5 @@ /** - * Copyright (c) 2025 miwa + * Copyright (c) 2025 favewa * SPDX-License-Identifier: AGPL-3.0-or-later */ diff --git a/routes/_app.tsx b/routes/_app.tsx index d10def4..55707fc 100644 --- a/routes/_app.tsx +++ b/routes/_app.tsx @@ -1,5 +1,5 @@ /** - * Copyright (c) 2025 miwa + * Copyright (c) 2025 favewa * SPDX-License-Identifier: AGPL-3.0-or-later */ diff --git a/routes/_error.tsx b/routes/_error.tsx index a99d788..57b84a3 100644 --- a/routes/_error.tsx +++ b/routes/_error.tsx @@ -1,5 +1,5 @@ /** - * Copyright (c) 2025 miwa + * Copyright (c) 2025 favewa * SPDX-License-Identifier: AGPL-3.0-or-later */ diff --git a/routes/about.tsx b/routes/about.tsx deleted file mode 100644 index 472a920..0000000 --- a/routes/about.tsx +++ /dev/null @@ -1,77 +0,0 @@ -/** - * 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 1345158..1ac27db 100644 --- a/routes/index.tsx +++ b/routes/index.tsx @@ -1,5 +1,5 @@ /** - * Copyright (c) 2025 miwa + * Copyright (c) 2025 favewa * SPDX-License-Identifier: AGPL-3.0-or-later */ @@ -10,7 +10,6 @@ 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 ( @@ -18,14 +17,16 @@ export default function Home() {
    -

    Summary

    +

    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. Read more + 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.

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

    Code