diff --git a/.vscode/launch.json b/.vscode/launch.json
index d642209..230708d 100644
--- a/.vscode/launch.json
+++ b/.vscode/launch.json
@@ -1,11 +1,11 @@
{
- "version": "0.2.0",
- "configurations": [
- {
- "command": "./node_modules/.bin/astro dev",
- "name": "Development server",
- "request": "launch",
- "type": "node-terminal"
- }
- ]
+ "version": "0.2.0",
+ "configurations": [
+ {
+ "command": "./node_modules/.bin/astro dev",
+ "name": "Development server",
+ "request": "launch",
+ "type": "node-terminal"
+ }
+ ]
}
diff --git a/astro.config.ts b/astro.config.ts
index bc5be0b..0c14c5c 100644
--- a/astro.config.ts
+++ b/astro.config.ts
@@ -1,28 +1,25 @@
-import { defineConfig } from "astro/config";
+import sitemap from "@astrojs/sitemap";
import tailwind from "@astrojs/tailwind";
import remarkCallout from "@r4ai/remark-callout";
-import sitemap from "@astrojs/sitemap";
import umami from "@yeskunall/astro-umami";
-
+import { defineConfig } from "astro/config";
export default defineConfig({
- site: "https://blog.z0x.ca",
- integrations: [
- tailwind({
- nesting: true,
- }),
- umami({
- id: "b691181e-cad7-4c23-b16a-709872a0a7ab",
- endpointUrl: "https://umami.z0x.ca",
- }),
- sitemap(),
- ],
- markdown: {
- shikiConfig: {
- theme: "css-variables",
- },
- remarkPlugins: [
- remarkCallout,
- ],
- }
-});
\ No newline at end of file
+ site: "https://blog.z0x.ca",
+ integrations: [
+ tailwind({
+ nesting: true,
+ }),
+ umami({
+ id: "b691181e-cad7-4c23-b16a-709872a0a7ab",
+ endpointUrl: "https://umami.z0x.ca",
+ }),
+ sitemap(),
+ ],
+ markdown: {
+ shikiConfig: {
+ theme: "css-variables",
+ },
+ remarkPlugins: [remarkCallout],
+ },
+});
diff --git a/biome.json b/biome.json
new file mode 100644
index 0000000..427986d
--- /dev/null
+++ b/biome.json
@@ -0,0 +1,43 @@
+{
+ "$schema": "https://biomejs.dev/schemas/1.9.4/schema.json",
+ "vcs": {
+ "enabled": false,
+ "clientKind": "git",
+ "useIgnoreFile": false
+ },
+ "files": {
+ "ignoreUnknown": false,
+ "ignore": ["node_modules", "dist"]
+ },
+ "formatter": {
+ "enabled": true,
+ "indentStyle": "tab"
+ },
+ "organizeImports": {
+ "enabled": true
+ },
+ "linter": {
+ "enabled": true,
+ "rules": {
+ "recommended": true
+ }
+ },
+ "javascript": {
+ "formatter": {
+ "quoteStyle": "double"
+ }
+ },
+ "overrides": [
+ {
+ "include": ["*.astro"],
+ "linter": {
+ "rules": {
+ "style": {
+ "useConst": "off",
+ "useImportType": "off"
+ }
+ }
+ }
+ }
+ ]
+}
diff --git a/bun.lockb b/bun.lockb
index a083ab2..a331ca4 100755
Binary files a/bun.lockb and b/bun.lockb differ
diff --git a/dist/artix-install-guide/index.html b/dist/artix-install-guide/index.html
index ec50e88..1dab97e 100644
--- a/dist/artix-install-guide/index.html
+++ b/dist/artix-install-guide/index.html
@@ -209,7 +209,7 @@
var head = document.querySelector("head")
head.appendChild(script)
})()
-
+
Artix Linux install guide
Table of Contents
Introduction
diff --git a/package.json b/package.json
index fc232d0..8fd26ed 100644
--- a/package.json
+++ b/package.json
@@ -1,30 +1,32 @@
{
- "name": "blog.z0x.ca",
- "type": "module",
- "version": "1.0.0",
- "scripts": {
- "dev": "astro dev",
- "start": "astro dev",
- "build": "astro check && astro build",
- "preview": "astro preview",
- "astro": "astro"
- },
- "dependencies": {
- "@astrojs/check": "^0.9.4",
- "@astrojs/rss": "^4.0.11",
- "@astrojs/sitemap": "^3.2.1",
- "@astrojs/tailwind": "^5.1.4",
- "@fontsource/geist-mono": "^5.1.1",
- "@fontsource/geist-sans": "^5.1.0",
- "@r4ai/remark-callout": "^0.6.2",
- "@yeskunall/astro-umami": "^0.0.3",
- "astro": "^5.1.5",
- "clsx": "^2.1.1",
- "tailwind-merge": "^2.6.0",
- "tailwindcss": "^3.4.17",
- "typescript": "^5.7.3"
- },
- "devDependencies": {
- "@tailwindcss/typography": "^0.5.16"
- }
+ "name": "blog.z0x.ca",
+ "type": "module",
+ "version": "1.0.0",
+ "scripts": {
+ "dev": "astro dev",
+ "start": "astro dev",
+ "build": "astro check && astro build",
+ "preview": "astro preview",
+ "astro": "astro"
+ },
+ "dependencies": {
+ "@astrojs/check": "^0.9.4",
+ "@astrojs/rss": "^4.0.11",
+ "@astrojs/sitemap": "^3.2.1",
+ "@astrojs/tailwind": "^5.1.4",
+ "@fontsource/geist-mono": "^5.1.1",
+ "@fontsource/geist-sans": "^5.1.0",
+ "@r4ai/remark-callout": "^0.6.2",
+ "@yeskunall/astro-umami": "^0.0.3",
+ "astro": "^5.1.5",
+ "clsx": "^2.1.1",
+ "tailwind-merge": "^2.6.0",
+ "tailwindcss": "^3.4.17",
+ "typescript": "^5.7.3"
+ },
+ "devDependencies": {
+ "@biomejs/biome": "1.9.4",
+ "@tailwindcss/typography": "^0.5.16"
+ },
+ "trustedDependencies": ["@biomejs/biome"]
}
diff --git a/src/components/ArrowCard.astro b/src/components/ArrowCard.astro
index 9574dc9..7bd7db5 100644
--- a/src/components/ArrowCard.astro
+++ b/src/components/ArrowCard.astro
@@ -2,11 +2,11 @@
import type { CollectionEntry } from "astro:content";
type Props = {
- entry: CollectionEntry<"blog">;
+ entry: CollectionEntry<"blog">;
};
const { entry } = Astro.props as {
- entry: CollectionEntry<"blog">;
+ entry: CollectionEntry<"blog">;
};
---
diff --git a/src/components/BackToTop.astro b/src/components/BackToTop.astro
index 829f124..ba20fd2 100644
--- a/src/components/BackToTop.astro
+++ b/src/components/BackToTop.astro
@@ -1,7 +1,3 @@
----
-
----
-
diff --git a/src/components/Footer.astro b/src/components/Footer.astro
index 239f038..8bc26f1 100644
--- a/src/components/Footer.astro
+++ b/src/components/Footer.astro
@@ -1,6 +1,6 @@
---
-import Container from "@components/Container.astro";
import BackToTop from "@components/BackToTop.astro";
+import Container from "@components/Container.astro";
import { SITE } from "@consts";
---
diff --git a/src/components/FormattedDate.astro b/src/components/FormattedDate.astro
index ee266ae..2c43400 100644
--- a/src/components/FormattedDate.astro
+++ b/src/components/FormattedDate.astro
@@ -1,6 +1,6 @@
---
interface Props {
- date: Date;
+ date: Date;
}
const { date } = Astro.props;
diff --git a/src/components/Head.astro b/src/components/Head.astro
index 8796e5c..0c30419 100644
--- a/src/components/Head.astro
+++ b/src/components/Head.astro
@@ -24,9 +24,9 @@ import "@fontsource/geist-mono/800.css";
import "@fontsource/geist-mono/900.css";
interface Props {
- title: string;
- description: string;
- image?: string;
+ title: string;
+ description: string;
+ image?: string;
}
const { title, description, image = "/blog-placeholder-1.jpg" } = Astro.props;
diff --git a/src/components/Link.astro b/src/components/Link.astro
index d4ed5e8..414e5a3 100644
--- a/src/components/Link.astro
+++ b/src/components/Link.astro
@@ -2,18 +2,18 @@
import { cn } from "@lib/utils";
type Props = {
- href: string;
- external?: boolean;
- underline?: boolean;
- group?: boolean;
+ href: string;
+ external?: boolean;
+ underline?: boolean;
+ group?: boolean;
};
const {
- href,
- external,
- underline = true,
- group = false,
- ...rest
+ href,
+ external,
+ underline = true,
+ group = false,
+ ...rest
} = Astro.props;
---
diff --git a/src/components/TableOfContents.astro b/src/components/TableOfContents.astro
index cd36334..9578fb2 100644
--- a/src/components/TableOfContents.astro
+++ b/src/components/TableOfContents.astro
@@ -5,24 +5,24 @@ const { headings } = Astro.props;
const toc = buildToc(headings);
export interface Heading {
- depth: number;
- id: string;
- text: string;
+ depth: number;
+ id: string;
+ text: string;
}
function buildToc(headings: Heading[]) {
- const toc: Heading[] = [];
- const parentHeadings = new Map();
- headings.forEach((h) => {
- const heading = { ...h, subheadings: [] };
- parentHeadings.set(heading.depth, heading);
- if (heading.depth === 2) {
- toc.push(heading);
- } else {
- parentHeadings.get(heading.depth - 1).subheadings.push(heading);
- }
- });
- return toc;
+ const toc: Heading[] = [];
+ const parentHeadings = new Map();
+ headings.forEach((h) => {
+ const heading = { ...h, subheadings: [] };
+ parentHeadings.set(heading.depth, heading);
+ if (heading.depth === 2) {
+ toc.push(heading);
+ } else {
+ parentHeadings.get(heading.depth - 1).subheadings.push(heading);
+ }
+ });
+ return toc;
}
---
diff --git a/src/components/TableOfContentsHeading.astro b/src/components/TableOfContentsHeading.astro
index 1b8931f..bb4a591 100644
--- a/src/components/TableOfContentsHeading.astro
+++ b/src/components/TableOfContentsHeading.astro
@@ -1,6 +1,6 @@
---
-import type { Heading } from "./TableOfContents.astro";
import Link from "./Link.astro";
+import type { Heading } from "./TableOfContents.astro";
const { heading } = Astro.props;
---
diff --git a/src/consts.ts b/src/consts.ts
index 60718a7..b6f3379 100644
--- a/src/consts.ts
+++ b/src/consts.ts
@@ -1,9 +1,8 @@
import type { Metadata, Site } from "@types";
export const SITE: Site = {
- TITLE: "z0x",
- DESCRIPTION: "z0x's blog",
+ TITLE: "z0x",
+ DESCRIPTION: "z0x's blog",
};
export const HOME: Metadata = {
- TITLE: "blog",
+ TITLE: "blog",
};
-
diff --git a/src/content.config.ts b/src/content.config.ts
index 6163f73..1a99685 100644
--- a/src/content.config.ts
+++ b/src/content.config.ts
@@ -1,14 +1,14 @@
import { defineCollection, z } from "astro:content";
-import { glob } from 'astro/loaders';
+import { glob } from "astro/loaders";
const blog = defineCollection({
- loader: glob({ pattern: '**/*.{md,mdx}', base: "./src/content" }),
- schema: z.object({
- title: z.string(),
- description: z.string(),
- date: z.coerce.date(),
- draft: z.boolean().optional(),
- }),
+ loader: glob({ pattern: "**/*.{md,mdx}", base: "./src/content" }),
+ schema: z.object({
+ title: z.string(),
+ description: z.string(),
+ date: z.coerce.date(),
+ draft: z.boolean().optional(),
+ }),
});
export const collections = { blog };
diff --git a/src/layouts/Layout.astro b/src/layouts/Layout.astro
index a4d8bcc..a5cdc3e 100644
--- a/src/layouts/Layout.astro
+++ b/src/layouts/Layout.astro
@@ -1,11 +1,11 @@
---
-import Head from "@components/Head.astro";
import Footer from "@components/Footer.astro";
+import Head from "@components/Head.astro";
import { SITE } from "@consts";
type Props = {
- title: string;
- description: string;
+ title: string;
+ description: string;
};
const { title, description } = Astro.props;
diff --git a/src/lib/utils.ts b/src/lib/utils.ts
index 294b335..39246bf 100644
--- a/src/lib/utils.ts
+++ b/src/lib/utils.ts
@@ -1,13 +1,13 @@
-import { clsx, type ClassValue } from "clsx";
+import { type ClassValue, clsx } from "clsx";
import { twMerge } from "tailwind-merge";
export function cn(...inputs: ClassValue[]) {
- return twMerge(clsx(inputs));
+ return twMerge(clsx(inputs));
}
export function readingTime(html: string) {
- const textOnly = html.replace(/<[^>]+>/g, "");
- const wordCount = textOnly.split(/\s+/).length;
- const readingTimeMinutes = (wordCount / 200 + 1).toFixed();
- return `${readingTimeMinutes} min read`;
+ const textOnly = html.replace(/<[^>]+>/g, "");
+ const wordCount = textOnly.split(/\s+/).length;
+ const readingTimeMinutes = (wordCount / 200 + 1).toFixed();
+ return `${readingTimeMinutes} min read`;
}
diff --git a/src/pages/404.astro b/src/pages/404.astro
index 04dd251..faa21f4 100644
--- a/src/pages/404.astro
+++ b/src/pages/404.astro
@@ -1,7 +1,7 @@
---
-import Layout from "@layouts/Layout.astro";
import Container from "@components/Container.astro";
import { SITE } from "@consts";
+import Layout from "@layouts/Layout.astro";
---
diff --git a/src/pages/[...id].astro b/src/pages/[...id].astro
index 4ed3241..6a86ae2 100644
--- a/src/pages/[...id].astro
+++ b/src/pages/[...id].astro
@@ -1,41 +1,45 @@
---
import { type CollectionEntry, getCollection, render } from "astro:content";
-import Layout from "@layouts/Layout.astro";
import Container from "@components/Container.astro";
import FormattedDate from "@components/FormattedDate.astro";
-import { readingTime } from "@lib/utils";
import PostNavigation from "@components/PostNavigation.astro";
import TableOfContents from "@components/TableOfContents.astro";
+import Layout from "@layouts/Layout.astro";
+import { readingTime } from "@lib/utils";
export async function getStaticPaths() {
- const posts = (await getCollection("blog")).filter((post) => !post.data.draft).sort((a, b) => b.data.date.valueOf() - a.data.date.valueOf());
- return posts.map((post) => ({
- params: { id: post.id },
- props: post,
- }));
+ const posts = (await getCollection("blog"))
+ .filter((post) => !post.data.draft)
+ .sort((a, b) => b.data.date.valueOf() - a.data.date.valueOf());
+ return posts.map((post) => ({
+ params: { id: post.id },
+ props: post,
+ }));
}
type Props = CollectionEntry<"blog">;
-const posts = (await getCollection("blog")).filter((post) => !post.data.draft).sort((a, b) => b.data.date.valueOf() - a.data.date.valueOf());
+const posts = (await getCollection("blog"))
+ .filter((post) => !post.data.draft)
+ .sort((a, b) => b.data.date.valueOf() - a.data.date.valueOf());
function getNextPost() {
- let postIndex;
- for (const post of posts) {
- if (post.id === Astro.params.id) {
- postIndex = posts.indexOf(post);
- return posts[postIndex + 1];
- }
- }
+ let postIndex;
+ for (const post of posts) {
+ if (post.id === Astro.params.id) {
+ postIndex = posts.indexOf(post);
+ return posts[postIndex + 1];
+ }
+ }
}
function getPrevPost() {
- let postIndex;
- for (const post of posts) {
- if (post.id === Astro.params.id) {
- postIndex = posts.indexOf(post);
- return posts[postIndex - 1];
- }
- }
+ let postIndex;
+ for (const post of posts) {
+ if (post.id === Astro.params.id) {
+ postIndex = posts.indexOf(post);
+ return posts[postIndex - 1];
+ }
+ }
}
const nextPost = getNextPost();
diff --git a/src/pages/index.astro b/src/pages/index.astro
index 2061916..2a8c6ae 100644
--- a/src/pages/index.astro
+++ b/src/pages/index.astro
@@ -1,27 +1,31 @@
---
import { type CollectionEntry, getCollection } from "astro:content";
-import Layout from "@layouts/Layout.astro";
-import Container from "@components/Container.astro";
import ArrowCard from "@components/ArrowCard.astro";
+import Container from "@components/Container.astro";
import { SITE } from "@consts";
import { HOME } from "@consts";
+import Layout from "@layouts/Layout.astro";
-const data = (await getCollection("blog")).filter((post) => !post.data.draft).sort((a, b) => b.data.date.valueOf() - a.data.date.valueOf());
+const data = (await getCollection("blog"))
+ .filter((post) => !post.data.draft)
+ .sort((a, b) => b.data.date.valueOf() - a.data.date.valueOf());
type Acc = {
- [year: string]: CollectionEntry<"blog">[];
+ [year: string]: CollectionEntry<"blog">[];
};
const posts = data.reduce((acc: Acc, post) => {
- const year = post.data.date.getFullYear().toString();
- if (!acc[year]) {
- acc[year] = [];
- }
- acc[year].push(post);
- return acc;
+ const year = post.data.date.getFullYear().toString();
+ if (!acc[year]) {
+ acc[year] = [];
+ }
+ acc[year].push(post);
+ return acc;
}, {});
-const years = Object.keys(posts).sort((a, b) => parseInt(b) - parseInt(a));
+const years = Object.keys(posts).sort(
+ (a, b) => Number.parseInt(b) - Number.parseInt(a),
+);
---
diff --git a/src/pages/rss.xml.js b/src/pages/rss.xml.js
index abd5110..7b21164 100644
--- a/src/pages/rss.xml.js
+++ b/src/pages/rss.xml.js
@@ -1,24 +1,23 @@
+import { getCollection } from "astro:content";
import rss from "@astrojs/rss";
import { SITE } from "@consts";
-import { getCollection } from "astro:content";
export async function GET(context) {
- const blog = (await getCollection("blog")).filter((post) => !post.data.draft);
+ const blog = (await getCollection("blog")).filter((post) => !post.data.draft);
+ const items = [...blog].sort(
+ (a, b) => new Date(b.data.date).valueOf() - new Date(a.data.date).valueOf(),
+ );
- const items = [...blog].sort(
- (a, b) => new Date(b.data.date).valueOf() - new Date(a.data.date).valueOf(),
- );
-
- return rss({
- title: SITE.TITLE,
- description: SITE.DESCRIPTION,
- site: context.site,
- items: items.map((item) => ({
- title: item.data.title,
- description: item.data.description,
- pubDate: item.data.date,
- link: `/${item.id}/`,
- })),
- });
+ return rss({
+ title: SITE.TITLE,
+ description: SITE.DESCRIPTION,
+ site: context.site,
+ items: items.map((item) => ({
+ title: item.data.title,
+ description: item.data.description,
+ pubDate: item.data.date,
+ link: `/${item.id}/`,
+ })),
+ });
}
diff --git a/src/styles/callout.css b/src/styles/callout.css
index 98cfacb..5529635 100644
--- a/src/styles/callout.css
+++ b/src/styles/callout.css
@@ -1,384 +1,395 @@
[data-callout] {
- & {
- @apply my-6 space-y-2 rounded-lg border border-blue-600/20 bg-blue-400/20 p-4 pb-5 dark:border-blue-800/20 dark:bg-blue-600/10;
- }
+ & {
+ @apply my-6 space-y-2 rounded-lg border border-blue-600/20 bg-blue-400/20 p-4 pb-5 dark:border-blue-800/20 dark:bg-blue-600/10;
+ }
- & > [data-callout-title] {
- & {
- @apply flex flex-row items-start gap-2 p-0 font-bold text-blue-500;
- }
+ & > [data-callout-title] {
+ & {
+ @apply flex flex-row items-start gap-2 p-0 font-bold text-blue-500;
+ }
- &:not:only-child {
- @apply mb-2;
- }
+ &:not:only-child {
+ @apply mb-2;
+ }
- &:empty::after {
- content: "Note";
- }
+ &:empty::after {
+ content: "Note";
+ }
- &::before {
- @apply mt-1 block h-5 w-5 bg-current content-[""];
- mask-repeat: no-repeat;
- mask-size: cover;
+ &::before {
+ @apply mt-1 block h-5 w-5 bg-current content-[""];
+ mask-repeat: no-repeat;
+ mask-size: cover;
- /* lucide-pencil */
- mask-image: url("");
- }
- }
+ /* lucide-pencil */
+ mask-image: url("");
+ }
+ }
- & > [data-callout-body] {
- & {
- @apply space-y-2;
- }
+ & > [data-callout-body] {
+ & {
+ @apply space-y-2;
+ }
- & > * {
- @apply m-0;
- }
- }
+ & > * {
+ @apply m-0;
+ }
+ }
}
details[data-callout] > summary[data-callout-title] {
- & {
- @apply cursor-pointer;
- }
+ & {
+ @apply cursor-pointer;
+ }
- &::after {
- @apply w-full bg-right bg-no-repeat;
- content: "";
+ &::after {
+ @apply w-full bg-right bg-no-repeat;
+ content: "";
- /* lucide:chevron-right */
- background-image: url("");
- background-size: 1.5rem;
- }
+ /* lucide:chevron-right */
+ background-image: url("");
+ background-size: 1.5rem;
+ }
- &:not(:empty)::after {
- @apply my-auto ml-auto h-6 w-6;
- }
+ &:not(:empty)::after {
+ @apply my-auto ml-auto h-6 w-6;
+ }
}
details[data-callout][open] > summary[data-callout-title]::after {
- /* lucide:chevron-down */
- background-image: url("");
+ /* lucide:chevron-down */
+ background-image: url("");
}
[data-callout][data-callout-type="info"] {
- & {
- @apply border-blue-600/20 bg-blue-400/20 dark:border-blue-800/20 dark:bg-blue-600/10;
- }
+ & {
+ @apply border-blue-600/20 bg-blue-400/20 dark:border-blue-800/20 dark:bg-blue-600/10;
+ }
- & > [data-callout-title] {
- & {
- @apply text-blue-500;
- }
+ & > [data-callout-title] {
+ & {
+ @apply text-blue-500;
+ }
- &:empty::after {
- content: "Info";
- }
+ &:empty::after {
+ content: "Info";
+ }
- &::before {
- /* lucide:info */
- mask-image: url("");
- }
- }
+ &::before {
+ /* lucide:info */
+ mask-image: url("");
+ }
+ }
}
[data-callout][data-callout-type="todo"] {
- & {
- @apply border-blue-600/20 bg-blue-400/20 dark:border-blue-800/20 dark:bg-blue-600/10;
- }
+ & {
+ @apply border-blue-600/20 bg-blue-400/20 dark:border-blue-800/20 dark:bg-blue-600/10;
+ }
- & > [data-callout-title] {
- & {
- @apply text-blue-500;
- }
+ & > [data-callout-title] {
+ & {
+ @apply text-blue-500;
+ }
- &:empty::after {
- content: "ToDo";
- }
+ &:empty::after {
+ content: "ToDo";
+ }
- &::before {
- /* lucide:circle-check-big */
- mask-image: url("");
- }
- }
+ &::before {
+ /* lucide:circle-check-big */
+ mask-image: url("");
+ }
+ }
}
[data-callout][data-callout-type="abstract"],
[data-callout][data-callout-type="summary"],
[data-callout][data-callout-type="tldr"] {
- & {
- @apply border-cyan-600/20 bg-cyan-400/20 dark:border-cyan-800/20 dark:bg-cyan-600/10;
- }
+ & {
+ @apply border-cyan-600/20 bg-cyan-400/20 dark:border-cyan-800/20 dark:bg-cyan-600/10;
+ }
- & > [data-callout-title] {
- & {
- @apply text-cyan-500;
- }
+ & > [data-callout-title] {
+ & {
+ @apply text-cyan-500;
+ }
- &::before {
- /* lucide:clipboard-list */
- mask-image: url("");
- }
- }
+ &::before {
+ /* lucide:clipboard-list */
+ mask-image: url("");
+ }
+ }
}
-[data-callout][data-callout-type="abstract"] > [data-callout-title]:empty::after {
- content: "Abstract";
+[data-callout][data-callout-type="abstract"]
+ > [data-callout-title]:empty::after {
+ content: "Abstract";
}
-[data-callout][data-callout-type="summary"] > [data-callout-title]:empty::after {
- content: "Summary";
+[data-callout][data-callout-type="summary"]
+ > [data-callout-title]:empty::after {
+ content: "Summary";
}
[data-callout][data-callout-type="tldr"] > [data-callout-title]:empty::after {
- content: "TL;DR";
+ content: "TL;DR";
}
[data-callout][data-callout-type="tip"],
[data-callout][data-callout-type="hint"],
[data-callout][data-callout-type="important"] {
- & {
- @apply border-cyan-600/20 bg-cyan-400/20 dark:border-cyan-800/20 dark:bg-cyan-600/10;
- }
+ & {
+ @apply border-cyan-600/20 bg-cyan-400/20 dark:border-cyan-800/20 dark:bg-cyan-600/10;
+ }
- & > [data-callout-title] {
- & {
- @apply text-cyan-500;
- }
+ & > [data-callout-title] {
+ & {
+ @apply text-cyan-500;
+ }
- &::before {
- /* lucide:flame */
- mask-image: url("");
- }
- }
+ &::before {
+ /* lucide:flame */
+ mask-image: url("");
+ }
+ }
}
[data-callout][data-callout-type="tip"] > [data-callout-title]:empty::after {
- content: "Tip";
+ content: "Tip";
}
[data-callout][data-callout-type="hint"] > [data-callout-title]:empty::after {
- content: "Hint";
+ content: "Hint";
}
-[data-callout][data-callout-type="important"] > [data-callout-title]:empty::after {
- content: "Important";
+[data-callout][data-callout-type="important"]
+ > [data-callout-title]:empty::after {
+ content: "Important";
}
[data-callout][data-callout-type="success"],
[data-callout][data-callout-type="check"],
[data-callout][data-callout-type="done"] {
- & {
- @apply border-green-600/20 bg-green-400/20 dark:border-green-800/20 dark:bg-green-600/10;
- }
+ & {
+ @apply border-green-600/20 bg-green-400/20 dark:border-green-800/20 dark:bg-green-600/10;
+ }
- & > [data-callout-title] {
- & {
- @apply text-green-500;
- }
+ & > [data-callout-title] {
+ & {
+ @apply text-green-500;
+ }
- &::before {
- /* lucide:check */
- mask-image: url("");
- }
- }
+ &::before {
+ /* lucide:check */
+ mask-image: url("");
+ }
+ }
}
-[data-callout][data-callout-type="success"] > [data-callout-title]:empty::after {
- content: "Success";
+[data-callout][data-callout-type="success"]
+ > [data-callout-title]:empty::after {
+ content: "Success";
}
[data-callout][data-callout-type="check"] > [data-callout-title]:empty::after {
- content: "Check";
+ content: "Check";
}
[data-callout][data-callout-type="done"] > [data-callout-title]:empty::after {
- content: "Done";
+ content: "Done";
}
[data-callout][data-callout-type="question"],
[data-callout][data-callout-type="help"],
[data-callout][data-callout-type="faq"] {
- & {
- @apply border-orange-600/20 bg-orange-400/20 dark:border-orange-800/20 dark:bg-orange-600/10;
- }
+ & {
+ @apply border-orange-600/20 bg-orange-400/20 dark:border-orange-800/20 dark:bg-orange-600/10;
+ }
- & > [data-callout-title] {
- & {
- @apply text-orange-500;
- }
+ & > [data-callout-title] {
+ & {
+ @apply text-orange-500;
+ }
- &::before {
- /* lucide:circle-help */
- mask-image: url("");
- }
- }
+ &::before {
+ /* lucide:circle-help */
+ mask-image: url("");
+ }
+ }
}
-[data-callout][data-callout-type="question"] > [data-callout-title]:empty::after {
- content: "Question";
+[data-callout][data-callout-type="question"]
+ > [data-callout-title]:empty::after {
+ content: "Question";
}
[data-callout][data-callout-type="help"] > [data-callout-title]:empty::after {
- content: "Help";
+ content: "Help";
}
[data-callout][data-callout-type="faq"] > [data-callout-title]:empty::after {
- content: "FAQ";
+ content: "FAQ";
}
[data-callout][data-callout-type="warning"],
[data-callout][data-callout-type="caution"],
[data-callout][data-callout-type="attention"] {
- & {
- @apply border-orange-600/20 bg-orange-400/20 dark:border-orange-800/20 dark:bg-orange-600/10;
- }
+ & {
+ @apply border-orange-600/20 bg-orange-400/20 dark:border-orange-800/20 dark:bg-orange-600/10;
+ }
- & > [data-callout-title] {
- & {
- @apply text-orange-500;
- }
+ & > [data-callout-title] {
+ & {
+ @apply text-orange-500;
+ }
- &::before {
- /* lucide:triangle-alert */
- mask-image: url("");
- }
- }
+ &::before {
+ /* lucide:triangle-alert */
+ mask-image: url("");
+ }
+ }
}
-[data-callout][data-callout-type="warning"] > [data-callout-title]:empty::after {
- content: "Warning";
+[data-callout][data-callout-type="warning"]
+ > [data-callout-title]:empty::after {
+ content: "Warning";
}
-[data-callout][data-callout-type="caution"] > [data-callout-title]:empty::after {
- content: "Caution";
+[data-callout][data-callout-type="caution"]
+ > [data-callout-title]:empty::after {
+ content: "Caution";
}
-[data-callout][data-callout-type="attention"] > [data-callout-title]:empty::after {
- content: "Attention";
+[data-callout][data-callout-type="attention"]
+ > [data-callout-title]:empty::after {
+ content: "Attention";
}
[data-callout][data-callout-type="failure"],
[data-callout][data-callout-type="fail"],
[data-callout][data-callout-type="missing"] {
- & {
- @apply border-red-600/20 bg-red-400/20 dark:border-red-800/20 dark:bg-red-600/10;
- }
+ & {
+ @apply border-red-600/20 bg-red-400/20 dark:border-red-800/20 dark:bg-red-600/10;
+ }
- & > [data-callout-title] {
- & {
- @apply text-red-500;
- }
+ & > [data-callout-title] {
+ & {
+ @apply text-red-500;
+ }
- &::before {
- /* lucide:check */
- mask-image: url("");
- }
- }
+ &::before {
+ /* lucide:check */
+ mask-image: url("");
+ }
+ }
}
-[data-callout][data-callout-type="failure"] > [data-callout-title]:empty::after {
- content: "Failure";
+[data-callout][data-callout-type="failure"]
+ > [data-callout-title]:empty::after {
+ content: "Failure";
}
[data-callout][data-callout-type="fail"] > [data-callout-title]:empty::after {
- content: "Fail";
+ content: "Fail";
}
-[data-callout][data-callout-type="missing"] > [data-callout-title]:empty::after {
- content: "Missing";
+[data-callout][data-callout-type="missing"]
+ > [data-callout-title]:empty::after {
+ content: "Missing";
}
[data-callout][data-callout-type="danger"],
[data-callout][data-callout-type="error"] {
- & {
- @apply border-red-600/20 bg-red-400/20 dark:border-red-800/20 dark:bg-red-600/10;
- }
+ & {
+ @apply border-red-600/20 bg-red-400/20 dark:border-red-800/20 dark:bg-red-600/10;
+ }
- & > [data-callout-title] {
- & {
- @apply text-red-500;
- }
+ & > [data-callout-title] {
+ & {
+ @apply text-red-500;
+ }
- &::before {
- /* lucide:zap */
- mask-image: url("");
- }
- }
+ &::before {
+ /* lucide:zap */
+ mask-image: url("");
+ }
+ }
}
[data-callout][data-callout-type="danger"] > [data-callout-title]:empty::after {
- content: "Danger";
+ content: "Danger";
}
[data-callout][data-callout-type="error"] > [data-callout-title]:empty::after {
- content: "Error";
+ content: "Error";
}
[data-callout][data-callout-type="bug"] {
- & {
- @apply border-red-600/20 bg-red-400/20 dark:border-red-800/20 dark:bg-red-600/10;
- }
+ & {
+ @apply border-red-600/20 bg-red-400/20 dark:border-red-800/20 dark:bg-red-600/10;
+ }
- & > [data-callout-title] {
- & {
- @apply text-red-500;
- }
+ & > [data-callout-title] {
+ & {
+ @apply text-red-500;
+ }
- &::before {
- /* lucide:bug */
- mask-image: url("");
- }
- }
+ &::before {
+ /* lucide:bug */
+ mask-image: url("");
+ }
+ }
}
[data-callout][data-callout-type="bug"] > [data-callout-title]:empty::after {
- content: "Bug";
+ content: "Bug";
}
[data-callout][data-callout-type="example"] {
- & {
- @apply border-purple-600/20 bg-purple-400/20 dark:border-purple-800/20 dark:bg-purple-600/10;
- }
+ & {
+ @apply border-purple-600/20 bg-purple-400/20 dark:border-purple-800/20 dark:bg-purple-600/10;
+ }
- & > [data-callout-title] {
- & {
- @apply text-purple-500;
- }
+ & > [data-callout-title] {
+ & {
+ @apply text-purple-500;
+ }
- &::before {
- /* lucide:list */
- mask-image: url("");
- }
- }
+ &::before {
+ /* lucide:list */
+ mask-image: url("");
+ }
+ }
}
-[data-callout][data-callout-type="example"] > [data-callout-title]:empty::after {
- content: "Example";
+[data-callout][data-callout-type="example"]
+ > [data-callout-title]:empty::after {
+ content: "Example";
}
[data-callout][data-callout-type="quote"],
[data-callout][data-callout-type="cite"] {
- & {
- @apply border-zinc-600/20 bg-zinc-400/20 dark:border-zinc-800/20 dark:bg-zinc-600/15;
- }
+ & {
+ @apply border-zinc-600/20 bg-zinc-400/20 dark:border-zinc-800/20 dark:bg-zinc-600/15;
+ }
- & > [data-callout-title] {
- & {
- @apply text-zinc-500;
- }
+ & > [data-callout-title] {
+ & {
+ @apply text-zinc-500;
+ }
- &::before {
- /* lucide:quote */
- mask-image: url("");
- }
- }
+ &::before {
+ /* lucide:quote */
+ mask-image: url("");
+ }
+ }
}
[data-callout][data-callout-type="quote"] > [data-callout-title]:empty::after {
- content: "Quote";
+ content: "Quote";
}
[data-callout][data-callout-type="cite"] > [data-callout-title]:empty::after {
- content: "Cite";
-}
\ No newline at end of file
+ content: "Cite";
+}
diff --git a/src/styles/global.css b/src/styles/global.css
index cfffdfa..0f1c3b0 100644
--- a/src/styles/global.css
+++ b/src/styles/global.css
@@ -3,114 +3,114 @@
@tailwind utilities;
html {
- overflow-y: auto;
- color-scheme: light;
- scroll-padding-top: 100px;
+ overflow-y: auto;
+ color-scheme: light;
+ scroll-padding-top: 100px;
}
html.dark {
- color-scheme: dark;
+ color-scheme: dark;
}
html,
body {
- @apply size-full;
+ @apply size-full;
}
body {
- @apply font-sans antialiased;
- @apply flex flex-col;
- @apply bg-neutral-100 dark:bg-neutral-900;
- @apply text-black/75 dark:text-white/75;
+ @apply font-sans antialiased;
+ @apply flex flex-col;
+ @apply bg-neutral-100 dark:bg-neutral-900;
+ @apply text-black/75 dark:text-white/75;
}
header {
- @apply fixed left-0 right-0 top-0 z-50 py-6;
- @apply bg-neutral-100/75 dark:bg-neutral-900/75;
- @apply saturate-200 backdrop-blur-sm;
+ @apply fixed left-0 right-0 top-0 z-50 py-6;
+ @apply bg-neutral-100/75 dark:bg-neutral-900/75;
+ @apply saturate-200 backdrop-blur-sm;
}
main {
- @apply flex-1 py-10;
+ @apply flex-1 py-10;
}
footer {
- @apply py-6 text-sm;
+ @apply py-6 text-sm;
}
article {
- @apply prose prose-neutral max-w-full dark:prose-invert prose-img:mx-auto prose-img:my-auto;
- @apply prose-headings:font-semibold;
- @apply prose-headings:text-black prose-headings:dark:text-white;
+ @apply prose prose-neutral max-w-full dark:prose-invert prose-img:mx-auto prose-img:my-auto;
+ @apply prose-headings:font-semibold;
+ @apply prose-headings:text-black prose-headings:dark:text-white;
}
@layer utilities {
- article a {
- @apply font-sans text-current underline underline-offset-[3px];
- @apply decoration-black/30 dark:decoration-white/30;
- @apply transition-colors duration-300 ease-in-out;
- }
- article a:hover {
- @apply text-black dark:text-white;
- @apply decoration-black/50 dark:decoration-white/50;
- }
+ article a {
+ @apply font-sans text-current underline underline-offset-[3px];
+ @apply decoration-black/30 dark:decoration-white/30;
+ @apply transition-colors duration-300 ease-in-out;
+ }
+ article a:hover {
+ @apply text-black dark:text-white;
+ @apply decoration-black/50 dark:decoration-white/50;
+ }
}
.animate {
- @apply -translate-y-3 opacity-0;
- @apply transition-all duration-300 ease-out;
+ @apply -translate-y-3 opacity-0;
+ @apply transition-all duration-300 ease-out;
}
.animate.show {
- @apply translate-y-0 opacity-100;
+ @apply translate-y-0 opacity-100;
}
html #back-to-top {
- @apply pointer-events-none opacity-0;
+ @apply pointer-events-none opacity-0;
}
html.scrolled #back-to-top {
- @apply pointer-events-auto opacity-100;
+ @apply pointer-events-auto opacity-100;
}
pre {
- @apply border border-black/15 py-5 dark:border-white/20;
+ @apply border border-black/15 py-5 dark:border-white/20;
}
:root {
- --astro-code-foreground: #09090b;
- --astro-code-background: #fafafa;
- --astro-code-token-comment: #a19595;
- --astro-code-token-keyword: #f47067;
- --astro-code-token-string: #00a99a;
- --astro-code-token-function: #429996;
- --astro-code-token-constant: #2b70c5;
- --astro-code-token-parameter: #4e8fdf;
- --astro-code-token-string-expression: #ae42a0;
- --astro-code-token-punctuation: #8996a3;
- --astro-code-token-link: #8d85ff;
+ --astro-code-foreground: #09090b;
+ --astro-code-background: #fafafa;
+ --astro-code-token-comment: #a19595;
+ --astro-code-token-keyword: #f47067;
+ --astro-code-token-string: #00a99a;
+ --astro-code-token-function: #429996;
+ --astro-code-token-constant: #2b70c5;
+ --astro-code-token-parameter: #4e8fdf;
+ --astro-code-token-string-expression: #ae42a0;
+ --astro-code-token-punctuation: #8996a3;
+ --astro-code-token-link: #8d85ff;
}
.dark {
- --astro-code-foreground: #fafafa;
- --astro-code-background: #09090b;
- --astro-code-token-comment: #a19595;
- --astro-code-token-keyword: #f47067;
- --astro-code-token-string: #00a99a;
- --astro-code-token-function: #6eafad;
- --astro-code-token-constant: #b3cceb;
- --astro-code-token-parameter: #4e8fdf;
- --astro-code-token-string-expression: #bf7db6;
- --astro-code-token-punctuation: #8996a3;
- --astro-code-token-link: #8d85ff;
+ --astro-code-foreground: #fafafa;
+ --astro-code-background: #09090b;
+ --astro-code-token-comment: #a19595;
+ --astro-code-token-keyword: #f47067;
+ --astro-code-token-string: #00a99a;
+ --astro-code-token-function: #6eafad;
+ --astro-code-token-constant: #b3cceb;
+ --astro-code-token-parameter: #4e8fdf;
+ --astro-code-token-string-expression: #bf7db6;
+ --astro-code-token-punctuation: #8996a3;
+ --astro-code-token-link: #8d85ff;
}
.copy-code {
- @apply absolute right-3 top-3 grid size-9 place-content-center rounded border border-black/15 bg-neutral-100 text-center duration-300 ease-in-out dark:border-white/20 dark:bg-neutral-900;
+ @apply absolute right-3 top-3 grid size-9 place-content-center rounded border border-black/15 bg-neutral-100 text-center duration-300 ease-in-out dark:border-white/20 dark:bg-neutral-900;
}
.copy-code:hover {
- @apply bg-[#E9E9E9] transition-colors dark:bg-[#232323];
+ @apply bg-[#E9E9E9] transition-colors dark:bg-[#232323];
}
.copy-code:active {
- @apply scale-90 transition-transform;
+ @apply scale-90 transition-transform;
}
diff --git a/src/types.ts b/src/types.ts
index 11b6c55..8e08d91 100644
--- a/src/types.ts
+++ b/src/types.ts
@@ -1,7 +1,7 @@
export type Site = {
- TITLE: string;
- DESCRIPTION: string;
+ TITLE: string;
+ DESCRIPTION: string;
};
export type Metadata = {
- TITLE: string;
-};
\ No newline at end of file
+ TITLE: string;
+};
diff --git a/tailwind.config.mjs b/tailwind.config.mjs
index 25f1f15..fd16b4b 100644
--- a/tailwind.config.mjs
+++ b/tailwind.config.mjs
@@ -1,15 +1,15 @@
import defaultTheme from "tailwindcss/defaultTheme";
/** @type {import('tailwindcss').Config} */
export default {
- darkMode: "class",
- content: ["./src/**/*.{astro,html,js,jsx,md,mdx,svelte,ts,tsx,vue}"],
- theme: {
- extend: {
- fontFamily: {
- sans: ["Geist Sans", ...defaultTheme.fontFamily.sans],
- mono: ["Geist Mono", ...defaultTheme.fontFamily.mono],
- },
- },
- },
- plugins: [require("@tailwindcss/typography")],
+ darkMode: "class",
+ content: ["./src/**/*.{astro,html,js,jsx,md,mdx,svelte,ts,tsx,vue}"],
+ theme: {
+ extend: {
+ fontFamily: {
+ sans: ["Geist Sans", ...defaultTheme.fontFamily.sans],
+ mono: ["Geist Mono", ...defaultTheme.fontFamily.mono],
+ },
+ },
+ },
+ plugins: [require("@tailwindcss/typography")],
};
diff --git a/tsconfig.json b/tsconfig.json
index 101caaa..d0935a9 100644
--- a/tsconfig.json
+++ b/tsconfig.json
@@ -1,12 +1,12 @@
{
- "extends": "astro/tsconfigs/strict",
- "include": [".astro/types.d.ts", "**/*"],
- "exclude": ["dist"],
- "compilerOptions": {
- "strictNullChecks": true,
- "baseUrl": ".",
- "paths": {
- "@*": ["./src/*"]
- }
- }
+ "extends": "astro/tsconfigs/strict",
+ "include": [".astro/types.d.ts", "**/*"],
+ "exclude": ["dist"],
+ "compilerOptions": {
+ "strictNullChecks": true,
+ "baseUrl": ".",
+ "paths": {
+ "@*": ["./src/*"]
+ }
+ }
}