From 787a07a9a265383050b562bbe6904e9342a3d140 Mon Sep 17 00:00:00 2001 From: mehbark Date: Mon, 10 Jul 2023 14:52:20 -0400 Subject: [PATCH] hot take first skeleton done --- html/common.tsx | 7 ++ html/coq.tsx | 5 +- html/dialogue.tsx | 3 +- ...eople_who_eat_croissants_are_dangerous.tsx | 68 +++++++++++++++++++ 4 files changed, 79 insertions(+), 4 deletions(-) create mode 100644 html/common.tsx create mode 100644 html/hot_people_who_eat_croissants_are_dangerous.tsx diff --git a/html/common.tsx b/html/common.tsx new file mode 100644 index 0000000..9d32c21 --- /dev/null +++ b/html/common.tsx @@ -0,0 +1,7 @@ +import { Component } from "./jsx/jsx-runtime.ts"; + +export const Main: Component = (attributes, children) => ( +
+ {...children} +
+); diff --git a/html/coq.tsx b/html/coq.tsx index ccdf536..50b132c 100644 --- a/html/coq.tsx +++ b/html/coq.tsx @@ -1,3 +1,4 @@ +import { Main } from "./common.tsx"; import { reify_dialogue } from "./dialogue.tsx"; import { debug_render } from "./html.ts"; import { Component } from "./jsx/jsx-runtime.ts"; @@ -250,8 +251,8 @@ const dialogue = reify_dialogue([ ]); debug_render( -
+
{dialogue}
-
+ ); diff --git a/html/dialogue.tsx b/html/dialogue.tsx index 14476cd..44d1608 100644 --- a/html/dialogue.tsx +++ b/html/dialogue.tsx @@ -1,5 +1,4 @@ -import { Html, debug_render } from "./html.ts"; -import { Component } from "./jsx/jsx-runtime.ts"; +import { Html } from "./html.ts"; type DOption = [Html, Dialogue]; type Dialogue = Html | [Html, ...DOption[]]; diff --git a/html/hot_people_who_eat_croissants_are_dangerous.tsx b/html/hot_people_who_eat_croissants_are_dangerous.tsx new file mode 100644 index 0000000..66521ec --- /dev/null +++ b/html/hot_people_who_eat_croissants_are_dangerous.tsx @@ -0,0 +1,68 @@ +import { Html, debug_render } from "./html.ts"; +import { Component } from "./jsx/jsx-runtime.ts"; + +const wheel = (...items: Html[]): Html => ( +
+ {...items.map(i =>
{i} people
)} +
+); + +const Take: Component = ({ subjects, objects, adjectives }, _) => ( +
+ {wheel(...subjects)} who eat {wheel(...objects)} are{" "} + {wheel(...adjectives)} +
+); + +// might want to have the final item be seperate +debug_render( + +);