about summary refs log tree commit diff stats
path: root/components/components.go
diff options
context:
space:
mode:
authorMarkus Wüstenberg2022-11-03 11:32:16 +0100
committerGitHub2022-11-03 11:32:16 +0100
commitb12942fb32082729e862eb53b8c3962534561e83 (patch)
tree19ac18495f6adfb46bf70c67fd721bf7eb7b4e3c /components/components.go
parent3bb4e3efeac645acc02781af59a1399f6f8e0795 (diff)
downloadgomponents-b12942fb32082729e862eb53b8c3962534561e83.tar.lz
gomponents-b12942fb32082729e862eb53b8c3962534561e83.tar.zst
gomponents-b12942fb32082729e862eb53b8c3962534561e83.zip
Delete low-value helper components (#115)
I'd rather reserve the package for components that have proven
repeatedly useful, like `Classes` and `HTML5`.
Diffstat (limited to 'components/components.go')
-rw-r--r--components/components.go64
1 files changed, 64 insertions, 0 deletions
diff --git a/components/components.go b/components/components.go
new file mode 100644
index 0000000..379d18d
--- /dev/null
+++ b/components/components.go
@@ -0,0 +1,64 @@
+// Package components provides high-level components and helpers that are composed of low-level elements and attributes.
+package components
+
+import (
+	"io"
+	"sort"
+	"strings"
+
+	g "github.com/maragudk/gomponents"
+	. "github.com/maragudk/gomponents/html"
+)
+
+// HTML5Props for HTML5.
+// Title is set no matter what, Description and Language elements only if the strings are non-empty.
+type HTML5Props struct {
+	Title       string
+	Description string
+	Language    string
+	Head        []g.Node
+	Body        []g.Node
+}
+
+// HTML5 document template.
+func HTML5(p HTML5Props) g.Node {
+	return Doctype(
+		HTML(g.If(p.Language != "", Lang(p.Language)),
+			Head(
+				Meta(Charset("utf-8")),
+				Meta(Name("viewport"), Content("width=device-width, initial-scale=1")),
+				TitleEl(g.Text(p.Title)),
+				g.If(p.Description != "", Meta(Name("description"), Content(p.Description))),
+				g.Group(p.Head),
+			),
+			Body(g.Group(p.Body)),
+		),
+	)
+}
+
+// Classes is a map of strings to booleans, which Renders to an attribute with name "class".
+// The attribute value is a sorted, space-separated string of all the map keys,
+// for which the corresponding map value is true.
+type Classes map[string]bool
+
+func (c Classes) Render(w io.Writer) error {
+	var included []string
+	for c, include := range c {
+		if include {
+			included = append(included, c)
+		}
+	}
+	sort.Strings(included)
+	return Class(strings.Join(included, " ")).Render(w)
+}
+
+func (c Classes) Type() g.NodeType {
+	return g.AttributeType
+}
+
+// String satisfies fmt.Stringer.
+func (c Classes) String() string {
+	var b strings.Builder
+	_ = c.Render(&b)
+	return b.String()
+}