From 674fe965550444db87edc7937ff6932e1a918d9d Mon Sep 17 00:00:00 2001 From: nsfisis Date: Fri, 27 Jun 2025 23:39:31 +0900 Subject: feat(meta): rename vhosts/ directory to services/ --- vhosts/blog/nuldoc-src/jsx/render.ts | 45 ------------------------------------ 1 file changed, 45 deletions(-) delete mode 100644 vhosts/blog/nuldoc-src/jsx/render.ts (limited to 'vhosts/blog/nuldoc-src/jsx/render.ts') diff --git a/vhosts/blog/nuldoc-src/jsx/render.ts b/vhosts/blog/nuldoc-src/jsx/render.ts deleted file mode 100644 index 8603f6c3..00000000 --- a/vhosts/blog/nuldoc-src/jsx/render.ts +++ /dev/null @@ -1,45 +0,0 @@ -import type { Element, Node } from "../dom.ts"; -import type { - JSXNode, - JSXNullableSimpleNode, - JSXSimpleNode, - RenderableJSXNode, -} from "myjsx/jsx-runtime"; - -function transformNode(node: JSXNode): Promise { - const flattenNodes: JSXNullableSimpleNode[] = Array.isArray(node) - // @ts-ignore prevents infinite recursion - ? (node.flat(Infinity) as JSXNullableSimpleNode[]) - : [node]; - return Promise.all( - flattenNodes - .filter((c): c is JSXSimpleNode => c != null && c !== false) - .map((c) => { - if (typeof c === "string") { - return { kind: "text", content: c, raw: false }; - } else if ("kind" in c) { - return c; - } else { - return renderToDOM(c); - } - }), - ); -} - -export async function renderToDOM( - element: RenderableJSXNode, -): Promise { - const { tag, props } = element; - if (typeof tag === "string") { - const { children, ...attrs } = props; - const attrsMap = new Map(Object.entries(attrs)) as Map; - return { - kind: "element", - name: tag, - attributes: attrsMap, - children: await transformNode(children), - }; - } else { - return renderToDOM(await tag(props)); - } -} -- cgit v1.2.3-70-g09d2