all repos — gomponents @ f7812a9f06d2b97f413b6b33deecba170e05d184

HTML components in pure Go

Add package attr with attribute helpers (#7)

Markus Wüstenberg markus@maragu.dk
Fri, 18 Sep 2020 14:44:47 +0200
commit

f7812a9f06d2b97f413b6b33deecba170e05d184

parent

f9d584c9889276000171046bcc2e32177514f552

2 files changed, 64 insertions(+), 0 deletions(-)

jump to
A attr/attributes.go
@@ -0,0 +1,33 @@+// Package attr provides shortcuts and helpers to common HTML attributes.
+// See https://developer.mozilla.org/en-US/docs/Web/HTML/Attributes for a list of attributes.
+package attr
+
+import (
+	"sort"
+	"strings"
+
+	g "github.com/maragudk/gomponents"
+)
+
+// ID returns an attribute with name "id" and the given value.
+func ID(v string) g.Node {
+	return g.Attr("id", v)
+}
+
+// Class returns an attribute with name "class" and the given value.
+func Class(v string) g.Node {
+	return g.Attr("class", v)
+}
+
+// Classes returns an attribute with name "class" and the value being a sorted, space-separated string of all the keys,
+// for which the corresponding value is true.
+func Classes(cs map[string]bool) g.Node {
+	var included []string
+	for c, include := range cs {
+		if include {
+			included = append(included, c)
+		}
+	}
+	sort.Strings(included)
+	return g.Attr("class", strings.Join(included, " "))
+}
A attr/attributes_test.go
@@ -0,0 +1,31 @@+package attr_test
+
+import (
+	"testing"
+
+	"github.com/maragudk/gomponents/assert"
+	"github.com/maragudk/gomponents/attr"
+)
+
+func TestID(t *testing.T) {
+	t.Run("given a value, returns id=value", func(t *testing.T) {
+		assert.Equal(t, ` id="hat"`, attr.ID("hat"))
+	})
+}
+
+func TestClass(t *testing.T) {
+	t.Run("given a value, returns class=value", func(t *testing.T) {
+		assert.Equal(t, ` class="hat"`, attr.Class("hat"))
+	})
+}
+
+func TestClasses(t *testing.T) {
+	t.Run("given a map, returns sorted keys from the map with value true", func(t *testing.T) {
+		assert.Equal(t, ` class="boheme-hat hat partyhat"`, attr.Classes(map[string]bool{
+			"boheme-hat": true,
+			"hat":        true,
+			"partyhat":   true,
+			"turtlehat":  false,
+		}))
+	})
+}