From c13420c3abff60061e141fa2abaface3319e4820 Mon Sep 17 00:00:00 2001 From: Max Richter Date: Sun, 2 Nov 2025 21:58:02 +0100 Subject: [PATCH] chore: deno fmt --- README.md | 2 +- components/Image.tsx | 5 +- components/PageHero.tsx | 15 +-- compose.yml | 10 +- drizzle/meta/0000_snapshot.json | 2 +- drizzle/meta/0001_snapshot.json | 2 +- drizzle/meta/0002_snapshot.json | 2 +- drizzle/meta/0003_snapshot.json | 2 +- drizzle/meta/0004_snapshot.json | 2 +- drizzle/meta/0005_snapshot.json | 2 +- drizzle/meta/0006_snapshot.json | 2 +- drizzle/meta/0007_snapshot.json | 2 +- drizzle/meta/0008_snapshot.json | 2 +- drizzle/meta/0009_snapshot.json | 2 +- drizzle/meta/0010_snapshot.json | 2 +- drizzle/meta/_journal.json | 2 +- islands/IngredientsList.tsx | 24 ++--- islands/KMenu/types.ts | 2 +- islands/Search.tsx | 20 ++-- lib/hooks/useDebouncedCallback.ts | 1 - lib/hooks/useThrottledCallback.ts | 1 - lib/marka/index.ts | 2 +- lib/openai.ts | 9 +- lib/taskManager.ts | 5 +- routes/admin/log/index.tsx | 2 +- routes/api/images/index.ts | 5 +- routes/api/recipes/create/index.ts | 5 +- routes/api/recommendation/all.ts | 3 +- routes/api/series/enhance/[name].ts | 2 +- routes/articles/[name].tsx | 19 ++-- routes/index.tsx | 5 +- routes/movies/[name].tsx | 2 +- routes/movies/index.tsx | 2 +- static/browserconfig.xml | 12 +-- static/global.css | 39 ++++---- static/logo.svg | 23 ++++- static/placeholder.svg | 40 ++++++-- static/prism-material-dark.css | 132 +++++++++++++-------------- static/prism-twilight.css | 136 +++++++++++++++------------- static/safari-pinned-tab.svg | 29 ++++-- static/thumbhash.js | 2 +- 41 files changed, 324 insertions(+), 254 deletions(-) diff --git a/README.md b/README.md index 844e5b2..2820dea 100644 --- a/README.md +++ b/README.md @@ -15,7 +15,7 @@ deno task start This will watch the project directory and restart as necessary. -## FIX +## FIX ``` sed -i -e 's/"deno"/"no-deno"/' node_modules/@libsql/client/package.json diff --git a/components/Image.tsx b/components/Image.tsx index abe7c2a..a4aea94 100644 --- a/components/Image.tsx +++ b/components/Image.tsx @@ -64,8 +64,9 @@ const Image = ( style={props.style} srcset={responsiveAttributes.srcset} sizes={responsiveAttributes.sizes} - src={`/api/images?image=${asset(props.src)}${props.width ? `&width=${props.width}` : "" - }${props.height ? `&height=${props.height}` : ""}`} + src={`/api/images?image=${asset(props.src)}${ + props.width ? `&width=${props.width}` : "" + }${props.height ? `&height=${props.height}` : ""}`} width={props.width} height={props.height} class={props.class} diff --git a/components/PageHero.tsx b/components/PageHero.tsx index 664ecf5..03d1cd1 100644 --- a/components/PageHero.tsx +++ b/components/PageHero.tsx @@ -20,8 +20,9 @@ function Wrapper( ) { return (
{image && @@ -51,8 +52,9 @@ function Title( return (

diff --git a/compose.yml b/compose.yml index 98ac27b..d094980 100644 --- a/compose.yml +++ b/compose.yml @@ -4,10 +4,10 @@ services: context: . dockerfile: Dockerfile volumes: - - .:/app # Mount the local directory to /app in the container - working_dir: /app # Set the working directory inside the container to /app - command: run --env-file -A --watch=static/,routes/ dev.ts # Custom start command + - .:/app # Mount the local directory to /app in the container + working_dir: /app # Set the working directory inside the container to /app + command: run --env-file -A --watch=static/,routes/ dev.ts # Custom start command ports: - - "8000:8000" # Expose the container port + - "8000:8000" # Expose the container port environment: - - DATA_DIR=/app/data # Set the environment variable inside the container + - DATA_DIR=/app/data # Set the environment variable inside the container diff --git a/drizzle/meta/0000_snapshot.json b/drizzle/meta/0000_snapshot.json index b3ac4dc..4c3c195 100644 --- a/drizzle/meta/0000_snapshot.json +++ b/drizzle/meta/0000_snapshot.json @@ -132,4 +132,4 @@ "internal": { "indexes": {} } -} \ No newline at end of file +} diff --git a/drizzle/meta/0001_snapshot.json b/drizzle/meta/0001_snapshot.json index 34018bf..f0463e3 100644 --- a/drizzle/meta/0001_snapshot.json +++ b/drizzle/meta/0001_snapshot.json @@ -132,4 +132,4 @@ "internal": { "indexes": {} } -} \ No newline at end of file +} diff --git a/drizzle/meta/0002_snapshot.json b/drizzle/meta/0002_snapshot.json index 5c64472..6f60580 100644 --- a/drizzle/meta/0002_snapshot.json +++ b/drizzle/meta/0002_snapshot.json @@ -178,4 +178,4 @@ "internal": { "indexes": {} } -} \ No newline at end of file +} diff --git a/drizzle/meta/0003_snapshot.json b/drizzle/meta/0003_snapshot.json index 2ccf97c..318fce1 100644 --- a/drizzle/meta/0003_snapshot.json +++ b/drizzle/meta/0003_snapshot.json @@ -223,4 +223,4 @@ "internal": { "indexes": {} } -} \ No newline at end of file +} diff --git a/drizzle/meta/0004_snapshot.json b/drizzle/meta/0004_snapshot.json index 7863ee0..6d6aaf1 100644 --- a/drizzle/meta/0004_snapshot.json +++ b/drizzle/meta/0004_snapshot.json @@ -223,4 +223,4 @@ "internal": { "indexes": {} } -} \ No newline at end of file +} diff --git a/drizzle/meta/0005_snapshot.json b/drizzle/meta/0005_snapshot.json index 3a2ba8b..2db595a 100644 --- a/drizzle/meta/0005_snapshot.json +++ b/drizzle/meta/0005_snapshot.json @@ -225,4 +225,4 @@ "internal": { "indexes": {} } -} \ No newline at end of file +} diff --git a/drizzle/meta/0006_snapshot.json b/drizzle/meta/0006_snapshot.json index 205bc86..a47db9b 100644 --- a/drizzle/meta/0006_snapshot.json +++ b/drizzle/meta/0006_snapshot.json @@ -230,4 +230,4 @@ "internal": { "indexes": {} } -} \ No newline at end of file +} diff --git a/drizzle/meta/0007_snapshot.json b/drizzle/meta/0007_snapshot.json index 59525eb..b94df60 100644 --- a/drizzle/meta/0007_snapshot.json +++ b/drizzle/meta/0007_snapshot.json @@ -230,4 +230,4 @@ "internal": { "indexes": {} } -} \ No newline at end of file +} diff --git a/drizzle/meta/0008_snapshot.json b/drizzle/meta/0008_snapshot.json index a49129f..e2ae7a4 100644 --- a/drizzle/meta/0008_snapshot.json +++ b/drizzle/meta/0008_snapshot.json @@ -230,4 +230,4 @@ "internal": { "indexes": {} } -} \ No newline at end of file +} diff --git a/drizzle/meta/0009_snapshot.json b/drizzle/meta/0009_snapshot.json index e35e811..9efda51 100644 --- a/drizzle/meta/0009_snapshot.json +++ b/drizzle/meta/0009_snapshot.json @@ -306,4 +306,4 @@ "internal": { "indexes": {} } -} \ No newline at end of file +} diff --git a/drizzle/meta/0010_snapshot.json b/drizzle/meta/0010_snapshot.json index 3d6d9fe..3e41fa2 100644 --- a/drizzle/meta/0010_snapshot.json +++ b/drizzle/meta/0010_snapshot.json @@ -308,4 +308,4 @@ "internal": { "indexes": {} } -} \ No newline at end of file +} diff --git a/drizzle/meta/_journal.json b/drizzle/meta/_journal.json index c4b474b..6fb34bc 100644 --- a/drizzle/meta/_journal.json +++ b/drizzle/meta/_journal.json @@ -80,4 +80,4 @@ "breakpoints": true } ] -} \ No newline at end of file +} diff --git a/islands/IngredientsList.tsx b/islands/IngredientsList.tsx index 1b0aa8d..c7513f1 100644 --- a/islands/IngredientsList.tsx +++ b/islands/IngredientsList.tsx @@ -62,15 +62,15 @@ export const IngredientsList: FunctionalComponent< > = ( { ingredients, amount, portion }, ) => { - return ( - - - {ingredients.map((item) => { - return ( - - ); - })} - -
- ); - }; + return ( + + + {ingredients.map((item) => { + return ( + + ); + })} + +
+ ); +}; diff --git a/islands/KMenu/types.ts b/islands/KMenu/types.ts index 3a0c3d8..14046ec 100644 --- a/islands/KMenu/types.ts +++ b/islands/KMenu/types.ts @@ -6,7 +6,7 @@ type IconKey = keyof typeof icons; export type MenuState = { activeMenu: Signal; activeState: Signal<"input" | "error" | "normal" | "loading">; - loadingText:Signal; + loadingText: Signal; commandInput: Signal; visible: Signal; menus: Record; diff --git a/islands/Search.tsx b/islands/Search.tsx index 48c132a..421f6af 100644 --- a/islands/Search.tsx +++ b/islands/Search.tsx @@ -191,16 +191,16 @@ const Search = ( {data.value?.length && !isLoading.value ? : isLoading.value - ?
- : ( -
- - No Results -
- )} + ?
+ : ( +
+ + No Results +
+ )}
); }; diff --git a/lib/hooks/useDebouncedCallback.ts b/lib/hooks/useDebouncedCallback.ts index 9a223fb..2fbc070 100644 --- a/lib/hooks/useDebouncedCallback.ts +++ b/lib/hooks/useDebouncedCallback.ts @@ -283,4 +283,3 @@ export default function useDebouncedCallback< return debounced; } - diff --git a/lib/hooks/useThrottledCallback.ts b/lib/hooks/useThrottledCallback.ts index fd8d29f..64b99f0 100644 --- a/lib/hooks/useThrottledCallback.ts +++ b/lib/hooks/useThrottledCallback.ts @@ -52,4 +52,3 @@ const useThrottledCallback = ( }; export default useThrottledCallback; - diff --git a/lib/marka/index.ts b/lib/marka/index.ts index 54dd34e..74e231f 100644 --- a/lib/marka/index.ts +++ b/lib/marka/index.ts @@ -12,7 +12,7 @@ async function addImageToResource( if (imageUrl) { try { const absoluteImageUrl = (imageUrl.startsWith("https://") || - imageUrl.startsWith("http://")) + imageUrl.startsWith("http://")) ? imageUrl : `${url}/${imageUrl}`; const image = await getImage(absoluteImageUrl); diff --git a/lib/openai.ts b/lib/openai.ts index 2145ad8..ac1e4a0 100644 --- a/lib/openai.ts +++ b/lib/openai.ts @@ -35,7 +35,8 @@ export async function summarize(content: string) { { role: "user", content: - `Please summarize the article in one sentence as short as possible: ${content.slice(0, 2000) + `Please summarize the article in one sentence as short as possible: ${ + content.slice(0, 2000) }`, }, ], @@ -102,7 +103,8 @@ export async function createGenres( { role: "system", content: - `you create some keywords that can be used in a recommendation system. The keywords are based on a ${type} description or title. If you do not know the title, take into account the description aswell. Create a range of keywords from very specific ones that describe the general vibe. ${title ? `The name of the ${type} is ${title}` : "" + `you create some keywords that can be used in a recommendation system. The keywords are based on a ${type} description or title. If you do not know the title, take into account the description aswell. Create a range of keywords from very specific ones that describe the general vibe. ${ + title ? `The name of the ${type} is ${title}` : "" }. Return a list of around 20 keywords seperated by commas`, }, { @@ -166,7 +168,8 @@ export const getMovieRecommendations = async ( ${keywords} -The movies should be similar to but not include ${exclude.join(", ") +The movies should be similar to but not include ${ + exclude.join(", ") } or remakes of that. respond with a plain unordered list each item starting with the year the movie was released and then the title of the movie seperated by a -`, diff --git a/lib/taskManager.ts b/lib/taskManager.ts index c58878f..e0c8013 100644 --- a/lib/taskManager.ts +++ b/lib/taskManager.ts @@ -48,8 +48,9 @@ export async function endTask(chatId: string): Promise { finalNote += "**[Voice message could not be transcribed]**\n\n"; } } else if (entry.type === "photo") { - const photoUrl = `${task.noteName.replace(/\.md$/, "") - }/photo-${photoIndex++}.jpg`; + const photoUrl = `${ + task.noteName.replace(/\.md$/, "") + }/photo-${photoIndex++}.jpg`; finalNote += `**Photo**:\n ${photoUrl}\n\n`; photoTasks.push({ diff --git a/routes/admin/log/index.tsx b/routes/admin/log/index.tsx index c43d1d2..1044e74 100644 --- a/routes/admin/log/index.tsx +++ b/routes/admin/log/index.tsx @@ -42,7 +42,7 @@ function LogLine( {log.date.getHours().toString().padStart(2, "0")}:{log.date .getMinutes().toString().padStart(2, "0")}:{log.date.getSeconds() - .toString().padStart(2, "0")} {formatDate(log.date)} + .toString().padStart(2, "0")} {formatDate(log.date)} {log.scope} diff --git a/routes/api/images/index.ts b/routes/api/images/index.ts index b6b086a..8738592 100644 --- a/routes/api/images/index.ts +++ b/routes/api/images/index.ts @@ -62,10 +62,11 @@ function parseParams(reqUrl: URL): ImageParams | string { // Helper function to generate ETag async function generateETag(content: ArrayBuffer): Promise { const hashBuffer = await crypto.subtle.digest("SHA-256", content); - return `"${Array.from(new Uint8Array(hashBuffer)) + return `"${ + Array.from(new Uint8Array(hashBuffer)) .map((b) => b.toString(16).padStart(2, "0")) .join("") - }"`; + }"`; } async function GET(req: Request, _ctx: FreshContext): Promise { diff --git a/routes/api/recipes/create/index.ts b/routes/api/recipes/create/index.ts index 33ab6ec..029e9f2 100644 --- a/routes/api/recipes/create/index.ts +++ b/routes/api/recipes/create/index.ts @@ -70,8 +70,9 @@ async function processCreateRecipeFromUrl( if (newRecipe?.image && newRecipe.image.length > 5) { const extension = fileExtension(new URL(newRecipe.image).pathname); - const finalPath = `resources/recipes/images/${safeFileName(id) - }_cover.${extension}`; + const finalPath = `resources/recipes/images/${ + safeFileName(id) + }_cover.${extension}`; streamResponse.enqueue("downloading image"); try { streamResponse.enqueue("downloading image"); diff --git a/routes/api/recommendation/all.ts b/routes/api/recommendation/all.ts index da3dccf..aa4b6f3 100644 --- a/routes/api/recommendation/all.ts +++ b/routes/api/recommendation/all.ts @@ -42,7 +42,8 @@ async function processUpdateRecommendations( } done++; streamResponse.enqueue( - `${Math.floor((done / total) * 100)}% [${done + 1 + `${Math.floor((done / total) * 100)}% [${ + done + 1 }/${total}] ${movie.name}`, ); })).catch((err) => { diff --git a/routes/api/series/enhance/[name].ts b/routes/api/series/enhance/[name].ts index 1984018..9c2f661 100644 --- a/routes/api/series/enhance/[name].ts +++ b/routes/api/series/enhance/[name].ts @@ -46,7 +46,7 @@ const POST = async ( } const posterPath = seriesDetails.poster_path; const director = seriesCredits && - seriesCredits.crew?.filter?.((person) => person.job === "Director")[0] || + seriesCredits.crew?.filter?.((person) => person.job === "Director")[0] || seriesDetails?.created_by?.[0]; if (director && director.name && !series.meta?.author) { series.author = series.author || {}; diff --git a/routes/articles/[name].tsx b/routes/articles/[name].tsx index 8cacdc6..a98fc7b 100644 --- a/routes/articles/[name].tsx +++ b/routes/articles/[name].tsx @@ -12,15 +12,16 @@ import { MetaTags } from "@components/MetaTags.tsx"; import { fetchResource } from "@lib/marka/index.ts"; import { ArticleResource } from "@lib/marka/schema.ts"; -export const handler: Handlers<{ article: ArticleResource; session: unknown }> = { - async GET(_, ctx) { - const article = await fetchResource(`articles/${ctx.params.name}.md`); - if (!article) { - return ctx.renderNotFound(); - } - return ctx.render({ article, session: ctx.state.session }); - }, -}; +export const handler: Handlers<{ article: ArticleResource; session: unknown }> = + { + async GET(_, ctx) { + const article = await fetchResource(`articles/${ctx.params.name}.md`); + if (!article) { + return ctx.renderNotFound(); + } + return ctx.render({ article, session: ctx.state.session }); + }, + }; export default function Greet( props: PageProps<{ article: Article; session: Record }>, diff --git a/routes/index.tsx b/routes/index.tsx index 3a99311..9e37396 100644 --- a/routes/index.tsx +++ b/routes/index.tsx @@ -22,10 +22,11 @@ export default function Home(props: PageProps) { ); diff --git a/routes/movies/[name].tsx b/routes/movies/[name].tsx index e04565d..81dadf9 100644 --- a/routes/movies/[name].tsx +++ b/routes/movies/[name].tsx @@ -24,7 +24,7 @@ export default async function Greet( return ctx.renderNotFound(); } - const { author = "", datePublished = "",reviewBody } = movie.content; + const { author = "", datePublished = "", reviewBody } = movie.content; const content = renderMarkdown( removeImage(reviewBody || "", movie.content.image), diff --git a/routes/movies/index.tsx b/routes/movies/index.tsx index 6ead4ec..2c1ffaa 100644 --- a/routes/movies/index.tsx +++ b/routes/movies/index.tsx @@ -21,7 +21,7 @@ export default async function MovieIndex( await searchResource({ ...searchParams, types: ["movie"] }); const movies = allMovies.sort((a, b) => a?.content?.reviewRating?.ratingValue > - b?.content?.reviewRating?.ratingValue + b?.content?.reviewRating?.ratingValue ? -1 : 1 ); diff --git a/static/browserconfig.xml b/static/browserconfig.xml index b3930d0..308bd45 100644 --- a/static/browserconfig.xml +++ b/static/browserconfig.xml @@ -1,9 +1,9 @@ - - - - #da532c - - + + + + #da532c + + diff --git a/static/global.css b/static/global.css index 8816f28..ab5c841 100644 --- a/static/global.css +++ b/static/global.css @@ -1,14 +1,14 @@ :root { --background: rgb(43, 41, 48); --foreground: rgb(129, 129, 129); - --light: #2B2930; + --light: #2b2930; } .custom-grid { grid-template-columns: repeat(auto-fit, minmax(37vw, 1fr)); } -@media(min-width: 640px) { +@media (min-width: 640px) { .custom-grid { grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); } @@ -16,19 +16,19 @@ /* work-sans-regular - latin */ @font-face { - font-family: 'Work Sans'; + font-family: "Work Sans"; font-style: normal; font-weight: 400; - src: url('/fonts/work-sans-v18-latin-regular.woff2') format('woff2'); + src: url("/fonts/work-sans-v18-latin-regular.woff2") format("woff2"); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */ } /* work-sans-700 - latin */ @font-face { - font-family: 'Work Sans'; + font-family: "Work Sans"; font-style: normal; font-weight: 700; - src: url('/fonts/work-sans-v18-latin-700.woff2') format('woff2'); + src: url("/fonts/work-sans-v18-latin-700.woff2") format("woff2"); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */ } @@ -51,7 +51,6 @@ a { } @keyframes hover { - 0%, 100% { transform: translateY(-15%); @@ -69,7 +68,7 @@ input::-webkit-inner-spin-button { } /* Firefox */ -input[type=number] { +input[type="number"] { -moz-appearance: textfield; appearance: textfield; } @@ -94,7 +93,7 @@ input[type=number] { height: 100%; width: 100%; filter: saturate(0) brightness(2); - background: url(''); + background: url(""); background-size: contain; background-position: 0px 0px; } @@ -109,11 +108,11 @@ input[type=number] { fill: #dcdbdc; } -.items-52>* { +.items-52 > * { height: 52px; } -.highlight>pre { +.highlight > pre { text-wrap: wrap; } @@ -129,24 +128,24 @@ main.loading { opacity: 0; } -.markdown-body>h1 { +.markdown-body > h1 { font-size: 2.25rem; font-weight: 600; } -.markdown-body>h2 { +.markdown-body > h2 { font-size: 1.75rem; font-weight: 600; } -.markdown-body>h3 { +.markdown-body > h3 { font-size: 1.5rem; font-weight: 600; } -.markdown-body>h1>.anchor, -.markdown-body>h2>.anchor, -.markdown-body>h3>.anchor { +.markdown-body > h1 > .anchor, +.markdown-body > h2 > .anchor, +.markdown-body > h3 > .anchor { display: inline-flex; margin-left: -26px; margin-right: 12px; @@ -154,8 +153,8 @@ main.loading { transition: opacity 0.2s; } -.markdown-body>h1:hover .anchor, -.markdown-body>h2:hover .anchor, -.markdown-body>h3:hover .anchor { +.markdown-body > h1:hover .anchor, +.markdown-body > h2:hover .anchor, +.markdown-body > h3:hover .anchor { opacity: 1; } diff --git a/static/logo.svg b/static/logo.svg index ef2fbe4..5b99e0b 100644 --- a/static/logo.svg +++ b/static/logo.svg @@ -1,6 +1,19 @@ - - - - - \ No newline at end of file + + + + + diff --git a/static/placeholder.svg b/static/placeholder.svg index f56716f..503de35 100644 --- a/static/placeholder.svg +++ b/static/placeholder.svg @@ -1,7 +1,35 @@ - - - - - - + + + + + + diff --git a/static/prism-material-dark.css b/static/prism-material-dark.css index 4d1da23..ad8683c 100644 --- a/static/prism-material-dark.css +++ b/static/prism-material-dark.css @@ -1,205 +1,205 @@ code[class*="language-"], pre[class*="language-"] { - text-align: left; - white-space: pre; - word-spacing: normal; - word-break: normal; - word-wrap: normal; - color: #eee; - background: #2f2f2f; - font-family: Roboto Mono, monospace; - font-size: 1em; - line-height: 1.5em; + text-align: left; + white-space: pre; + word-spacing: normal; + word-break: normal; + word-wrap: normal; + color: #eee; + background: #2f2f2f; + font-family: Roboto Mono, monospace; + font-size: 1em; + line-height: 1.5em; - -moz-tab-size: 4; - -o-tab-size: 4; - tab-size: 4; + -moz-tab-size: 4; + -o-tab-size: 4; + tab-size: 4; - -webkit-hyphens: none; - -moz-hyphens: none; - -ms-hyphens: none; - hyphens: none; + -webkit-hyphens: none; + -moz-hyphens: none; + -ms-hyphens: none; + hyphens: none; } code[class*="language-"]::-moz-selection, pre[class*="language-"]::-moz-selection, code[class*="language-"] ::-moz-selection, pre[class*="language-"] ::-moz-selection { - background: #363636; + background: #363636; } code[class*="language-"]::selection, pre[class*="language-"]::selection, code[class*="language-"] ::selection, pre[class*="language-"] ::selection { - background: #363636; + background: #363636; } :not(pre) > code[class*="language-"] { - white-space: normal; - border-radius: 0.2em; - padding: 0.1em; + white-space: normal; + border-radius: 0.2em; + padding: 0.1em; } pre[class*="language-"] { - overflow: auto; - position: relative; - margin: 0.5em 0; - padding: 1.25em 1em; + overflow: auto; + position: relative; + margin: 0.5em 0; + padding: 1.25em 1em; } .language-css > code, .language-sass > code, .language-scss > code { - color: #fd9170; + color: #fd9170; } [class*="language-"] .namespace { - opacity: 0.7; + opacity: 0.7; } .token.atrule { - color: #c792ea; + color: #c792ea; } .token.attr-name { - color: #ffcb6b; + color: #ffcb6b; } .token.attr-value { - color: #a5e844; + color: #a5e844; } .token.attribute { - color: #a5e844; + color: #a5e844; } .token.boolean { - color: #c792ea; + color: #c792ea; } .token.builtin { - color: #ffcb6b; + color: #ffcb6b; } .token.cdata { - color: #80cbc4; + color: #80cbc4; } .token.char { - color: #80cbc4; + color: #80cbc4; } .token.class { - color: #ffcb6b; + color: #ffcb6b; } .token.class-name { - color: #f2ff00; + color: #f2ff00; } .token.comment { - color: #616161; + color: #616161; } .token.constant { - color: #c792ea; + color: #c792ea; } .token.deleted { - color: #ff6666; + color: #ff6666; } .token.doctype { - color: #616161; + color: #616161; } .token.entity { - color: #ff6666; + color: #ff6666; } .token.function { - color: #c792ea; + color: #c792ea; } .token.hexcode { - color: #f2ff00; + color: #f2ff00; } .token.id { - color: #c792ea; - font-weight: bold; + color: #c792ea; + font-weight: bold; } .token.important { - color: #c792ea; - font-weight: bold; + color: #c792ea; + font-weight: bold; } .token.inserted { - color: #80cbc4; + color: #80cbc4; } .token.keyword { - color: #c792ea; + color: #c792ea; } .token.number { - color: #fd9170; + color: #fd9170; } .token.operator { - color: #89ddff; + color: #89ddff; } .token.prolog { - color: #616161; + color: #616161; } .token.property { - color: #80cbc4; + color: #80cbc4; } .token.pseudo-class { - color: #a5e844; + color: #a5e844; } .token.pseudo-element { - color: #a5e844; + color: #a5e844; } .token.punctuation { - color: #89ddff; + color: #89ddff; } .token.regex { - color: #f2ff00; + color: #f2ff00; } .token.selector { - color: #ff6666; + color: #ff6666; } .token.string { - color: #a5e844; + color: #a5e844; } .token.symbol { - color: #c792ea; + color: #c792ea; } .token.tag { - color: #ff6666; + color: #ff6666; } .token.unit { - color: #fd9170; + color: #fd9170; } .token.url { - color: #ff6666; + color: #ff6666; } .token.variable { - color: #ff6666; + color: #ff6666; } diff --git a/static/prism-twilight.css b/static/prism-twilight.css index 63cc4c6..feb2349 100644 --- a/static/prism-twilight.css +++ b/static/prism-twilight.css @@ -5,95 +5,99 @@ */ code[class*="language-"], pre[class*="language-"] { - color: white; - background: none; - font-family: Consolas, Monaco, 'Andale Mono', 'Ubuntu Mono', monospace; - font-size: 1em; - text-align: left; - text-shadow: 0 -.1em .2em black; - white-space: pre; - word-spacing: normal; - word-break: normal; - word-wrap: normal; - line-height: 1.5; + color: white; + background: none; + font-family: Consolas, Monaco, "Andale Mono", "Ubuntu Mono", monospace; + font-size: 1em; + text-align: left; + text-shadow: 0 -0.1em 0.2em black; + white-space: pre; + word-spacing: normal; + word-break: normal; + word-wrap: normal; + line-height: 1.5; - -moz-tab-size: 4; - -o-tab-size: 4; - tab-size: 4; + -moz-tab-size: 4; + -o-tab-size: 4; + tab-size: 4; - -webkit-hyphens: none; - -moz-hyphens: none; - -ms-hyphens: none; - hyphens: none; + -webkit-hyphens: none; + -moz-hyphens: none; + -ms-hyphens: none; + hyphens: none; } pre[class*="language-"], :not(pre) > code[class*="language-"] { - background: hsl(0, 0%, 8%); /* #141414 */ + background: hsl(0, 0%, 8%); /* #141414 */ } /* Code blocks */ pre[class*="language-"] { - border-radius: .5em; - border: .3em solid hsl(0, 0%, 33%); /* #282A2B */ - box-shadow: 1px 1px .5em black inset; - margin: .5em 0; - overflow: auto; - padding: 1em; + border-radius: 0.5em; + border: 0.3em solid hsl(0, 0%, 33%); /* #282A2B */ + box-shadow: 1px 1px 0.5em black inset; + margin: 0.5em 0; + overflow: auto; + padding: 1em; } pre[class*="language-"]::-moz-selection { - /* Firefox */ - background: hsl(200, 4%, 16%); /* #282A2B */ + /* Firefox */ + background: hsl(200, 4%, 16%); /* #282A2B */ } pre[class*="language-"]::selection { - /* Safari */ - background: hsl(200, 4%, 16%); /* #282A2B */ + /* Safari */ + background: hsl(200, 4%, 16%); /* #282A2B */ } /* Text Selection colour */ -pre[class*="language-"]::-moz-selection, pre[class*="language-"] ::-moz-selection, -code[class*="language-"]::-moz-selection, code[class*="language-"] ::-moz-selection { - text-shadow: none; - background: hsla(0, 0%, 93%, 0.15); /* #EDEDED */ +pre[class*="language-"]::-moz-selection, +pre[class*="language-"] ::-moz-selection, +code[class*="language-"]::-moz-selection, +code[class*="language-"] ::-moz-selection { + text-shadow: none; + background: hsla(0, 0%, 93%, 0.15); /* #EDEDED */ } -pre[class*="language-"]::selection, pre[class*="language-"] ::selection, -code[class*="language-"]::selection, code[class*="language-"] ::selection { - text-shadow: none; - background: hsla(0, 0%, 93%, 0.15); /* #EDEDED */ +pre[class*="language-"]::selection, +pre[class*="language-"] ::selection, +code[class*="language-"]::selection, +code[class*="language-"] ::selection { + text-shadow: none; + background: hsla(0, 0%, 93%, 0.15); /* #EDEDED */ } /* Inline code */ :not(pre) > code[class*="language-"] { - border-radius: .3em; - border: .13em solid hsl(0, 0%, 33%); /* #545454 */ - box-shadow: 1px 1px .3em -.1em black inset; - padding: .15em .2em .05em; - white-space: normal; + border-radius: 0.3em; + border: 0.13em solid hsl(0, 0%, 33%); /* #545454 */ + box-shadow: 1px 1px 0.3em -0.1em black inset; + padding: 0.15em 0.2em 0.05em; + white-space: normal; } .token.comment, .token.prolog, .token.doctype, .token.cdata { - color: hsl(0, 0%, 47%); /* #777777 */ + color: hsl(0, 0%, 47%); /* #777777 */ } .token.punctuation { - opacity: .7; + opacity: 0.7; } .token.namespace { - opacity: .7; + opacity: 0.7; } .token.tag, .token.boolean, .token.number, .token.deleted { - color: hsl(14, 58%, 55%); /* #CF6A4C */ + color: hsl(14, 58%, 55%); /* #CF6A4C */ } .token.keyword, @@ -102,7 +106,7 @@ code[class*="language-"]::selection, code[class*="language-"] ::selection { .token.constant, .token.symbol, .token.builtin { - color: hsl(53, 89%, 79%); /* #F9EE98 */ + color: hsl(53, 89%, 79%); /* #F9EE98 */ } .token.attr-name, @@ -116,54 +120,58 @@ code[class*="language-"]::selection, code[class*="language-"] ::selection { .style .token.string, .token.variable, .token.inserted { - color: hsl(76, 21%, 52%); /* #8F9D6A */ + color: hsl(76, 21%, 52%); /* #8F9D6A */ } .token.atrule { - color: hsl(218, 22%, 55%); /* #7587A6 */ + color: hsl(218, 22%, 55%); /* #7587A6 */ } .token.regex, .token.important { - color: hsl(42, 75%, 65%); /* #E9C062 */ + color: hsl(42, 75%, 65%); /* #E9C062 */ } .token.important, .token.bold { - font-weight: bold; + font-weight: bold; } .token.italic { - font-style: italic; + font-style: italic; } .token.entity { - cursor: help; + cursor: help; } /* Markup */ .language-markup .token.tag, .language-markup .token.attr-name, .language-markup .token.punctuation { - color: hsl(33, 33%, 52%); /* #AC885B */ + color: hsl(33, 33%, 52%); /* #AC885B */ } /* Make the tokens sit above the line highlight so the colours don't look faded. */ .token { - position: relative; - z-index: 1; + position: relative; + z-index: 1; } .line-highlight.line-highlight { - background: hsla(0, 0%, 33%, 0.25); /* #545454 */ - background: linear-gradient(to right, hsla(0, 0%, 33%, .1) 70%, hsla(0, 0%, 33%, 0)); /* #545454 */ - border-bottom: 1px dashed hsl(0, 0%, 33%); /* #545454 */ - border-top: 1px dashed hsl(0, 0%, 33%); /* #545454 */ - margin-top: 0.75em; /* Same as .prism’s padding-top */ - z-index: 0; + background: hsla(0, 0%, 33%, 0.25); /* #545454 */ + background: linear-gradient( + to right, + hsla(0, 0%, 33%, 0.1) 70%, + hsla(0, 0%, 33%, 0) + ); /* #545454 */ + border-bottom: 1px dashed hsl(0, 0%, 33%); /* #545454 */ + border-top: 1px dashed hsl(0, 0%, 33%); /* #545454 */ + margin-top: 0.75em; /* Same as .prism’s padding-top */ + z-index: 0; } .line-highlight.line-highlight:before, .line-highlight.line-highlight[data-end]:after { - background-color: hsl(215, 15%, 59%); /* #8794A6 */ - color: hsl(24, 20%, 95%); /* #F5F2F0 */ + background-color: hsl(215, 15%, 59%); /* #8794A6 */ + color: hsl(24, 20%, 95%); /* #F5F2F0 */ } diff --git a/static/safari-pinned-tab.svg b/static/safari-pinned-tab.svg index 915d8be..628dbd8 100644 --- a/static/safari-pinned-tab.svg +++ b/static/safari-pinned-tab.svg @@ -1,15 +1,25 @@ - - + + Created by potrace 1.14, written by Peter Selinger 2001-2017 - - + - +-15 2 -24 4 -8 1 -29 -3 -45 -10z" + /> + diff --git a/static/thumbhash.js b/static/thumbhash.js index e2049bd..2e74d83 100644 --- a/static/thumbhash.js +++ b/static/thumbhash.js @@ -35,7 +35,7 @@ function thumbHashToRGBA(hash) { for (let cx = cy ? 0 : 1; cx * ny < nx * (ny - cy); cx++) { ac.push( (((hash[ac_start + (ac_index >> 1)] >> ((ac_index++ & 1) << 2)) & - 15) / 7.5 - 1) * scale, + 15) / 7.5 - 1) * scale, ); } }