Move heavyweight imports out of WASM build via //go:build !js tags: - register.go: encoding/json + text/template (codegen) - pipeline.go: go-i18n/reversal (grammar imprint) - layout.go: replace fmt.Sprintf with string concat Add cmd/codegen/ CLI as build-time replacement for in-browser registerComponents(). Reads slot JSON from stdin, writes WC bundle JS to stdout. Result: 2.90MB raw / 830KB gzip (was 6.04MB / 1.56MB). Makefile gate passes (limit 1MB gzip). Co-Authored-By: Virgil <virgil@lethean.io>
59 lines
1.3 KiB
Go
59 lines
1.3 KiB
Go
//go:build js && wasm
|
|
|
|
package main
|
|
|
|
import (
|
|
"syscall/js"
|
|
|
|
html "forge.lthn.ai/core/go-html"
|
|
)
|
|
|
|
// renderToString builds an HLCRF layout from JS arguments and returns HTML.
|
|
// Slot content is injected via Raw() — the caller is responsible for sanitisation.
|
|
// This is intentional: the WASM module is a rendering engine for trusted content
|
|
// produced server-side or by the application's own templates.
|
|
func renderToString(_ js.Value, args []js.Value) any {
|
|
if len(args) < 1 {
|
|
return ""
|
|
}
|
|
|
|
variant := args[0].String()
|
|
ctx := html.NewContext()
|
|
|
|
if len(args) >= 2 {
|
|
ctx.Locale = args[1].String()
|
|
}
|
|
|
|
layout := html.NewLayout(variant)
|
|
|
|
if len(args) >= 3 && args[2].Type() == js.TypeObject {
|
|
slots := args[2]
|
|
for _, slot := range []string{"H", "L", "C", "R", "F"} {
|
|
content := slots.Get(slot)
|
|
if content.Type() == js.TypeString && content.String() != "" {
|
|
switch slot {
|
|
case "H":
|
|
layout.H(html.Raw(content.String()))
|
|
case "L":
|
|
layout.L(html.Raw(content.String()))
|
|
case "C":
|
|
layout.C(html.Raw(content.String()))
|
|
case "R":
|
|
layout.R(html.Raw(content.String()))
|
|
case "F":
|
|
layout.F(html.Raw(content.String()))
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
return layout.Render(ctx)
|
|
}
|
|
|
|
func main() {
|
|
js.Global().Set("gohtml", js.ValueOf(map[string]any{
|
|
"renderToString": js.FuncOf(renderToString),
|
|
}))
|
|
|
|
select {}
|
|
}
|