all repos — gomponents @ 3de9270f785082b70e5d3cb7212271d7ad86a6d9

HTML components in pure Go

Add better example in readme (#16)

Markus Wüstenberg markus@maragu.dk
Wed, 23 Sep 2020 22:05:59 +0200
commit

3de9270f785082b70e5d3cb7212271d7ad86a6d9

parent

eb2cfa10c2cfc763b18df4879d06223f2efaddfd

2 files changed, 34 insertions(+), 7 deletions(-)

jump to
M .editorconfig.editorconfig
@@ -11,5 +11,5 @@ [Makefile]
 indent_style = tab
 
-[*.go]
+[{*.go,*.md}]
 indent_style = tab
M README.mdREADME.md
@@ -21,23 +21,50 @@ Then do something like this:
 
 ```go
-package foo
+package main
 
 import (
-    "net/http"
+	"fmt"
+	"net/http"
 
-    g "github.com/maragudk/gomponents"
-    "github.com/maragudk/gomponents/el"
+	g "github.com/maragudk/gomponents"
+	"github.com/maragudk/gomponents/attr"
+	"github.com/maragudk/gomponents/el"
 )
 
 func main() {
-    _ = http.ListenAndServe("localhost:8080", handler())
+	_ = http.ListenAndServe("localhost:8080", handler())
 }
 
 func handler() http.HandlerFunc {
 	return func(w http.ResponseWriter, r *http.Request) {
-		_ = g.Write(w, el.Document(el.HTML(el.Head(el.Title("Hi!")), el.Body(el.H1("Hi!")))))
+		page := Page("Hi!", r.URL.Path)
+		_ = g.Write(w, page)
 	}
+}
+
+func Page(title, path string) g.Node {
+	return el.Document(
+		el.HTML(
+			g.Attr("lang", "en"),
+			el.Head(
+				el.Title(title),
+				el.Style(g.Attr("type", "text/css"), g.Raw(".is-active{font-weight: bold}")),
+			),
+			el.Body(
+				Navbar(path),
+				el.H1(title),
+				el.P(g.Text(fmt.Sprintf("Welcome to the page at %v.", path))),
+			),
+		),
+	)
+}
+
+func Navbar(path string) g.Node {
+	return g.El("nav",
+		el.A("/", attr.Classes{"is-active": path == "/"}, g.Text("Home")),
+		el.A("/about", attr.Classes{"is-active": path == "/about"}, g.Text("About")),
+	)
 }
 ```