From a129f3a37397c75883241f5736c813cd3af3b1b2 Mon Sep 17 00:00:00 2001 From: EthanThatOneKid <31261035+EthanThatOneKid@users.noreply.github.com> Date: Sat, 22 Jun 2024 11:40:46 -0700 Subject: [PATCH] initial commit --- README.md | 11 ++++++----- area.tsx | 3 +-- base.tsx | 3 +-- br.tsx | 3 +-- cli/codegen.ts | 8 ++++---- col.tsx | 3 +-- deno.json | 2 +- embed.tsx | 3 +-- hr.tsx | 3 +-- img.tsx | 3 +-- input.tsx | 3 +-- jsx-runtime.ts | 1 + link.tsx | 3 +-- meta.tsx | 3 +-- mod.ts | 1 + param.tsx | 3 +-- source.tsx | 3 +-- track.tsx | 3 +-- wbr.tsx | 3 +-- 19 files changed, 27 insertions(+), 38 deletions(-) create mode 100644 jsx-runtime.ts diff --git a/README.md b/README.md index d14c7ae..3bb1e55 100644 --- a/README.md +++ b/README.md @@ -2,7 +2,8 @@ [![GitHub Actions](https://github.com/FartLabs/htx/actions/workflows/check.yaml/badge.svg)](https://github.com/FartLabs/htx/actions/workflows/check.yaml) -Render HTML components with JSX. +Render HTML components with JSX powered by Deno and +[**@fartlabs/jsonx**](https://jsr.io/@fartlabs/jsonx). ## API documentation @@ -12,7 +13,7 @@ Generated API documentation is available at . ### Deno -Let's learn how to get started with rtx by creating a simple router in Deno. +Let's learn how to get started with htx by creating a simple router in Deno. 1\. [Install Deno](https://docs.deno.com/runtime/manual). @@ -22,10 +23,10 @@ Let's learn how to get started with rtx by creating a simple router in Deno. deno init ``` -3\. Add `@fartlabs/jsonx` and `@fartlabs/htx` as project dependencies. +3\. Add `@fartlabs/htx` as a project dependency. ```sh -deno add @fartlabs/jsonx @fartlabs/htx +deno add @fartlabs/htx ``` 4\. Add the following values to your `deno.json(c)` file. @@ -34,7 +35,7 @@ deno add @fartlabs/jsonx @fartlabs/htx { "compilerOptions": { "jsx": "react-jsx", - "jsxImportSource": "@fartlabs/jsonx" + "jsxImportSource": "@fartlabs/htx" } } ``` diff --git a/area.tsx b/area.tsx index 1415285..e8e4157 100644 --- a/area.tsx +++ b/area.tsx @@ -10,6 +10,5 @@ export type { AreaElementProps }; export function AREA( props: AreaElementProps & { children?: string[] } = {}, ): string { - const { children, ...rest } = props; - return render(rest); + return render(props); } diff --git a/base.tsx b/base.tsx index e104195..a331cdf 100644 --- a/base.tsx +++ b/base.tsx @@ -10,6 +10,5 @@ export type { BaseElementProps }; export function BASE( props: BaseElementProps & { children?: string[] } = {}, ): string { - const { children, ...rest } = props; - return render(rest); + return render(props); } diff --git a/br.tsx b/br.tsx index 063b619..ca106fe 100644 --- a/br.tsx +++ b/br.tsx @@ -10,6 +10,5 @@ export type { BrElementProps }; export function BR( props: BrElementProps & { children?: string[] } = {}, ): string { - const { children, ...rest } = props; - return render(rest); + return render(props); } diff --git a/cli/codegen.ts b/cli/codegen.ts index 5f58312..8aca3e8 100644 --- a/cli/codegen.ts +++ b/cli/codegen.ts @@ -45,11 +45,9 @@ if (import.meta.main) { initializer: "{}", }], returnType: "string", - statements: [ + statements: descriptor.isVoid ? ["return render(props);"] : [ "const { children, ...rest } = props;", - descriptor.isVoid - ? "return render(rest);" - : "return render(rest, ...(children ?? []));", + "return render(rest, ...(children ?? []));", ], docs: toDocs({ description: @@ -67,6 +65,7 @@ if (import.meta.main) { undefined, { overwrite: true }, ); + modFile.addStatements(`export * from "./special/mod.ts";`); for (const descriptor of descriptors) { modFile.addStatements(`export * from "./${descriptor.tag}.tsx";`); } @@ -78,6 +77,7 @@ if (import.meta.main) { const denoConfig = JSON.parse(await Deno.readTextFile("./deno.json")); denoConfig.exports = { ".": "./mod.ts", + "./jsx-runtime": "./jsx-runtime.ts", ...Object.fromEntries(descriptors.map((descriptor) => [ `./${descriptor.tag}`, `./${descriptor.tag}.tsx`, diff --git a/col.tsx b/col.tsx index 48788aa..3420f18 100644 --- a/col.tsx +++ b/col.tsx @@ -10,6 +10,5 @@ export type { ColElementProps }; export function COL( props: ColElementProps & { children?: string[] } = {}, ): string { - const { children, ...rest } = props; - return render(rest); + return render(props); } diff --git a/deno.json b/deno.json index 7b542e6..f2a6ea0 100644 --- a/deno.json +++ b/deno.json @@ -16,7 +16,7 @@ }, "exports": { ".": "./mod.ts", - "./special": "./special/mod.ts", + "./jsx-runtime": "./jsx-runtime.ts", "./a": "./a.tsx", "./abbr": "./abbr.tsx", "./acronym": "./acronym.tsx", diff --git a/embed.tsx b/embed.tsx index 14c12b7..d27b90d 100644 --- a/embed.tsx +++ b/embed.tsx @@ -10,6 +10,5 @@ export type { EmbedElementProps }; export function EMBED( props: EmbedElementProps & { children?: string[] } = {}, ): string { - const { children, ...rest } = props; - return render(rest); + return render(props); } diff --git a/hr.tsx b/hr.tsx index 1d9754e..73f7dc2 100644 --- a/hr.tsx +++ b/hr.tsx @@ -10,6 +10,5 @@ export type { HrElementProps }; export function HR( props: HrElementProps & { children?: string[] } = {}, ): string { - const { children, ...rest } = props; - return render(rest); + return render(props); } diff --git a/img.tsx b/img.tsx index 6d2617d..5a69a24 100644 --- a/img.tsx +++ b/img.tsx @@ -10,6 +10,5 @@ export type { ImgElementProps }; export function IMG( props: ImgElementProps & { children?: string[] } = {}, ): string { - const { children, ...rest } = props; - return render(rest); + return render(props); } diff --git a/input.tsx b/input.tsx index b7f4d53..f87e345 100644 --- a/input.tsx +++ b/input.tsx @@ -10,6 +10,5 @@ export type { InputElementProps }; export function INPUT( props: InputElementProps & { children?: string[] } = {}, ): string { - const { children, ...rest } = props; - return render(rest); + return render(props); } diff --git a/jsx-runtime.ts b/jsx-runtime.ts new file mode 100644 index 0000000..93fa75f --- /dev/null +++ b/jsx-runtime.ts @@ -0,0 +1 @@ +export * from "@fartlabs/jsonx/jsx-runtime"; diff --git a/link.tsx b/link.tsx index e0847f3..561219c 100644 --- a/link.tsx +++ b/link.tsx @@ -10,6 +10,5 @@ export type { LinkElementProps }; export function LINK( props: LinkElementProps & { children?: string[] } = {}, ): string { - const { children, ...rest } = props; - return render(rest); + return render(props); } diff --git a/meta.tsx b/meta.tsx index 16db6cd..ab38e87 100644 --- a/meta.tsx +++ b/meta.tsx @@ -10,6 +10,5 @@ export type { MetaElementProps }; export function META( props: MetaElementProps & { children?: string[] } = {}, ): string { - const { children, ...rest } = props; - return render(rest); + return render(props); } diff --git a/mod.ts b/mod.ts index c8c12da..4f77a2e 100644 --- a/mod.ts +++ b/mod.ts @@ -1,3 +1,4 @@ +export * from "./special/mod.ts"; export * from "./a.tsx"; export * from "./abbr.tsx"; export * from "./acronym.tsx"; diff --git a/param.tsx b/param.tsx index 39eaaa3..8d9b37b 100644 --- a/param.tsx +++ b/param.tsx @@ -11,6 +11,5 @@ export type { ParamElementProps }; export function PARAM( props: ParamElementProps & { children?: string[] } = {}, ): string { - const { children, ...rest } = props; - return render(rest); + return render(props); } diff --git a/source.tsx b/source.tsx index ec92a7d..f8b315d 100644 --- a/source.tsx +++ b/source.tsx @@ -10,6 +10,5 @@ export type { SourceElementProps }; export function SOURCE( props: SourceElementProps & { children?: string[] } = {}, ): string { - const { children, ...rest } = props; - return render(rest); + return render(props); } diff --git a/track.tsx b/track.tsx index 9c89fe5..2fd595b 100644 --- a/track.tsx +++ b/track.tsx @@ -10,6 +10,5 @@ export type { TrackElementProps }; export function TRACK( props: TrackElementProps & { children?: string[] } = {}, ): string { - const { children, ...rest } = props; - return render(rest); + return render(props); } diff --git a/wbr.tsx b/wbr.tsx index 08a279c..75f2055 100644 --- a/wbr.tsx +++ b/wbr.tsx @@ -10,6 +10,5 @@ export type { WbrElementProps }; export function WBR( props: WbrElementProps & { children?: string[] } = {}, ): string { - const { children, ...rest } = props; - return render(rest); + return render(props); }