From 16ae5821fdebdf3705de531268c5e8220c8517d2 Mon Sep 17 00:00:00 2001 From: Rokas Muningis <28229273+muningis@users.noreply.github.com> Date: Wed, 18 Dec 2024 20:27:58 +0200 Subject: [PATCH] feat: added MDX example --- mdx/content/blog/hello-world.mdx | 8 ++++++++ mdx/package.json | 12 +++++++++++ mdx/server/getContent.ts | 32 +++++++++++++++++++++++++++++ mdx/src/components/HonoInfoCard.tsx | 15 ++++++++++++++ mdx/src/index.tsx | 29 ++++++++++++++++++++++++++ mdx/tsconfig.json | 10 +++++++++ 6 files changed, 106 insertions(+) create mode 100644 mdx/content/blog/hello-world.mdx create mode 100644 mdx/package.json create mode 100644 mdx/server/getContent.ts create mode 100644 mdx/src/components/HonoInfoCard.tsx create mode 100644 mdx/src/index.tsx create mode 100644 mdx/tsconfig.json diff --git a/mdx/content/blog/hello-world.mdx b/mdx/content/blog/hello-world.mdx new file mode 100644 index 0000000..aa28409 --- /dev/null +++ b/mdx/content/blog/hello-world.mdx @@ -0,0 +1,8 @@ +--- +title: Hello world! +description: Example blog post using MDX on Hono webserver +--- + +This is markdown, but it has JSX components! + + \ No newline at end of file diff --git a/mdx/package.json b/mdx/package.json new file mode 100644 index 0000000..6da5a80 --- /dev/null +++ b/mdx/package.json @@ -0,0 +1,12 @@ +{ + "name": "mdx", + "license": "MIT", + "scripts": { + "dev": "bun run --hot src/index.tsx" + }, + "dependencies": { + "hono": "4.2.4", + "mdx-bundler": "10.0.3", + "esbuild": "0.24.0" + } +} diff --git a/mdx/server/getContent.ts b/mdx/server/getContent.ts new file mode 100644 index 0000000..b75f55c --- /dev/null +++ b/mdx/server/getContent.ts @@ -0,0 +1,32 @@ +import { bundleMDX } from "mdx-bundler"; +import { readFile } from "node:fs/promises"; +import { join } from "node:path"; + + +async function getContent(...params: string[]): Promise { + const file_path = join(process.cwd(), "content", ...params.slice(0, -1), `${params.at(-1)}.mdx`); + const [source] = await Promise.all([readFile(file_path, "utf-8")]); + + const post = await bundleMDX({ + source, + cwd: process.cwd(), + jsxConfig: { + JsxLib: { + varName: 'HonoJSX', + package: 'hono/jsx', + }, + JsxDom: { + varName: 'HonoDOM', + package: 'hono/jsx/dom', + }, + jsxRuntime: { + varName: '_jsx_runtime', + package: 'hono/jsx/jsx-runtime', + }, + } + }); + + return post; +} + +export { getContent }; diff --git a/mdx/src/components/HonoInfoCard.tsx b/mdx/src/components/HonoInfoCard.tsx new file mode 100644 index 0000000..8eb5ce7 --- /dev/null +++ b/mdx/src/components/HonoInfoCard.tsx @@ -0,0 +1,15 @@ +export const HonoInfoCard = () => { + return (
+
Hono
+
Web application framework
+ +
Benefits
+
Fast
+
Lightweight
+
Built on Web Standards
+
Support for any JavaScript runtime
+ +
Interested?
+
Click here to learn more
+
) +} \ No newline at end of file diff --git a/mdx/src/index.tsx b/mdx/src/index.tsx new file mode 100644 index 0000000..2515566 --- /dev/null +++ b/mdx/src/index.tsx @@ -0,0 +1,29 @@ +import { Hono } from "hono"; +import { getContent } from "../server/getContent"; + +import * as HonoJSX from "hono/jsx"; +import * as HonoDOM from "hono/jsx/dom"; +import * as _jsx_runtime from "hono/jsx/jsx-runtime"; +import { getMDXComponent } from "mdx-bundler/client"; +import { HonoInfoCard } from "./components/HonoInfoCard"; + +const app = new Hono(); + +const jsxComponents = { + HonoInfoCard +} + +app.get("/", (c) => { + return c.json({ foo: "Bar" }); +}).get("/blog/:slug", (c) => { + const { code, frontmater } = getContent("blog", c.req.param("slug")); + const Component = getMDXComponent(code, { HonoJSX, HonoDOM, _jsx_runtime }); + + return c.render(
+

{frontmater.title}

+ +
+ ) +}); + +export default app; diff --git a/mdx/tsconfig.json b/mdx/tsconfig.json new file mode 100644 index 0000000..9e267ec --- /dev/null +++ b/mdx/tsconfig.json @@ -0,0 +1,10 @@ +{ + "compilerOptions": { + "target": "ESNext", + "module": "ESNext", + "moduleResolution": "Bundler", + "strict": true, + "jsx": "react-jsx", + "jsxImportSource": "hono/jsx" + } +}