diff options
author | Markus Wüstenberg | 2022-11-03 11:32:16 +0100 |
---|---|---|
committer | GitHub | 2022-11-03 11:32:16 +0100 |
commit | b12942fb32082729e862eb53b8c3962534561e83 (patch) | |
tree | 19ac18495f6adfb46bf70c67fd721bf7eb7b4e3c /components/components.go | |
parent | 3bb4e3efeac645acc02781af59a1399f6f8e0795 (diff) | |
download | gomponents-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.go | 64 |
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() +} |