{report.excerpt}
{report.tags && ( )} 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( - '
',
+ '
',
)}
>
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 (
+ <>
+ + 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!{" "} +
+- 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
west@ko-fi
- misties@github
+ fukkai@github
]*>[\s\S]*?<\/pre>/gi, () => (preBlocks++, ""))
+ .replace(/]*>[\s\S]*?<\/code>/gi, () => (codeBlocks++, ""));
+
+ const cjkRegex = /[\u4E00-\u9FFF\u3040-\u309F\u30A0-\u30FF\uAC00-\uD7AF]/g;
+ const cjkMatches = text.match(cjkRegex);
+ const cjkCharacters = cjkMatches?.length ?? 0;
+
+ const textWithoutCJK = cjkCharacters ? text.replace(cjkRegex, " ") : text;
+ const words = textWithoutCJK.trim().split(/\s+/).reduce(
+ (n, w) => n + (w && /\w/.test(w) ? 1 : 0),
+ 0,
+ );
+
+ const totalMinutes = Math.ceil(
+ words / wordsPerMinute +
+ cjkCharacters / chineseKoreanReadingSpeed +
+ (images * imageTime + (preBlocks + codeBlocks) * codeBlockTime) / 60,
+ );
+
+ return {
+ minutes: Math.max(totalMinutes || 2, 2),
+ words: words + cjkCharacters,
+ images,
+ codeBlocks: preBlocks + codeBlocks,
+ };
+}
diff --git a/utils/fm.ts b/utils/fm.ts
index 8c3486e..722ef10 100644
--- a/utils/fm.ts
+++ b/utils/fm.ts
@@ -1,5 +1,5 @@
/**
- * Copyright (c) 2025 favewa
+ * Copyright (c) 2025 miwa
* SPDX-License-Identifier: AGPL-3.0-or-later
*/
diff --git a/utils/index.ts b/utils/index.ts
index fb91b5c..048ab19 100644
--- a/utils/index.ts
+++ b/utils/index.ts
@@ -1,5 +1,5 @@
/**
- * Copyright (c) 2025 favewa
+ * Copyright (c) 2025 miwa
* SPDX-License-Identifier: AGPL-3.0-or-later
*/
diff --git a/utils/temp.ts b/utils/temp.ts
index e41f6ed..12a5d11 100644
--- a/utils/temp.ts
+++ b/utils/temp.ts
@@ -1,5 +1,5 @@
/**
- * Copyright (c) 2025 favewa
+ * Copyright (c) 2025 miwa
* SPDX-License-Identifier: AGPL-3.0-or-later
*/
diff --git a/vite.config.ts b/vite.config.ts
index c6a225d..b249557 100644
--- a/vite.config.ts
+++ b/vite.config.ts
@@ -1,5 +1,5 @@
/**
- * Copyright (c) 2025 favewa
+ * Copyright (c) 2025 miwa
* SPDX-License-Identifier: AGPL-3.0-or-later
*/