htmgo/htmgo-site/partials/html-to-go.go
2024-10-25 08:12:11 -05:00

64 lines
1.7 KiB
Go

package partials
import (
"github.com/maddalax/htmgo/framework/h"
"github.com/maddalax/htmgo/framework/js"
"github.com/maddalax/htmgo/tools/html-to-htmgo/htmltogo"
"htmgo-site/ui"
)
func ConvertHtmlToGo(ctx *h.RequestContext) *h.Partial {
value := ctx.FormValue("html-input")
parsed := htmltogo.Parse([]byte(value))
formatted := ui.FormatCode(string(parsed), "height: 100%;")
return h.SwapPartial(ctx, GoOutput(formatted))
}
func HtmlInput() *h.Element {
return h.Div(
h.Class("h-full w-1/2 min-w-1/2"),
h.TextArea(
h.Name("html-input"),
h.MaxLength(500*1000),
h.PostPartial(ConvertHtmlToGo, "keyup delay:300ms"),
h.Class("h-[90%] w-full p-4 rounded border border-slate-200"),
h.Placeholder("Paste your HTML here"),
h.Rows(10),
),
)
}
func GoOutput(content string) *h.Element {
return h.Div(
h.Class("h-full w-1/2 min-w-1/2"),
h.Id("go-output"),
h.Div(
h.Class("h-[90%] w-full rounded border border-slate-200 relative"),
h.Div(
h.Class("h-full"),
h.Id("go-output-content"),
h.UnsafeRaw(content),
),
h.If(content != "", h.Div(
h.Class("absolute top-0 right-0 p-2 bg-slate-800 text-white rounded-bl-md cursor-pointer"),
h.Text("Copy"),
// language=JavaScript
h.OnClick(js.EvalJs(`
if(!navigator.clipboard) {
alert("Clipboard API not supported");
return;
}
let text = self.parentElement.querySelector("#go-output-content").innerText;
navigator.clipboard.writeText(text);
self.innerText = "Copied!";
setTimeout(() => {
self.innerText = "Copy";
}, 1000);
`)),
)),
),
)
}