From 7ef8366bfc43775bf26e71e77bddf31af829dfde Mon Sep 17 00:00:00 2001 From: Josh Kingsley Date: Wed, 29 Oct 2025 18:26:41 +0200 Subject: refactor(web): add decorators --- web/src/html.ts | 44 ++++++++++++++++++++++++++++---------------- 1 file changed, 28 insertions(+), 16 deletions(-) (limited to 'web/src/html.ts') diff --git a/web/src/html.ts b/web/src/html.ts index 8802e50..a118849 100644 --- a/web/src/html.ts +++ b/web/src/html.ts @@ -1,3 +1,29 @@ +export function createElement( + tag: string, + ...children: (Node | string)[] +): T; + +export function createElement( + tag: string, + attrs: Partial, + ...children: (Node | string)[] +): T; + +export function createElement(tag: string, ...args: any[]) { + const el = document.createElement(tag); + + if (args[0]?.constructor === Object) { + const { dataset, style, ...attrs } = args.shift(); + Object.assign(el, attrs); + if (dataset) Object.assign(el.dataset, dataset); + if (style) Object.assign(el.style, style); + } + + el.append(...args.flat()); + + return el; +} + export type CreateElement = { (...children: (Node | string)[]): T; (attrs: Partial, ...children: (Node | string)[]): T; @@ -9,23 +35,9 @@ type ElementCreator = { const h = new Proxy({} as ElementCreator, { get: - (_, tag: string) => + (_, tagName: string) => (...args: any[]) => { - const el = document.createElement(tag); - - if (args[0]?.constructor === Object) { - const { dataset, ...attrs } = args.shift(); - - Object.assign(el, attrs); - - if (dataset) { - Object.assign(el.dataset, dataset); - } - } - - el.append(...args.flat()); - - return el; + return createElement(tagName, ...args); }, }); -- cgit v1.2.3