about summary refs log tree commit diff stats
diff options
context:
space:
mode:
authorMarkus Wüstenberg2020-12-22 10:53:22 +0100
committerGitHub2020-12-22 10:53:22 +0100
commitf22ce3fb68ca6702a683b7759410ae50a9fddabd (patch)
treeaace6553bb5c48b99d7205fe56d6b7d630b7799a
parent428a2519eaa8e16767f86b417abd5af007f24fc6 (diff)
downloadgomponents-f22ce3fb68ca6702a683b7759410ae50a9fddabd.tar.lz
gomponents-f22ce3fb68ca6702a683b7759410ae50a9fddabd.tar.zst
gomponents-f22ce3fb68ca6702a683b7759410ae50a9fddabd.zip
Add If helper function (#57)
Used to inline conditional nodes.
-rw-r--r--components/elements.go10
-rw-r--r--gomponents.go19
-rw-r--r--gomponents_test.go12
3 files changed, 38 insertions, 3 deletions
diff --git a/components/elements.go b/components/elements.go
new file mode 100644
index 0000000..baffba6
--- /dev/null
+++ b/components/elements.go
@@ -0,0 +1,10 @@
+package components
+
+import (
+	g "github.com/maragudk/gomponents"
+	. "github.com/maragudk/gomponents/html"
+)
+
+func InputHidden(name, value string, children ...g.Node) g.NodeFunc {
+	return Input(Type("hidden"), Name(name), Value(value), g.Group(children))
+}
diff --git a/gomponents.go b/gomponents.go
index de46b7c..1986a1e 100644
--- a/gomponents.go
+++ b/gomponents.go
@@ -222,11 +222,11 @@ func Group(children []Node) Node {
 // Example:
 // 	items := []string{"hat", "partyhat"}
 //
-// 	lis := g.Map(len(items), func(i int) g.Node {
-// 		return g.El("li", g.Text(items[i]))
+// 	lis := Map(len(items), func(i int) Node {
+// 		return El("li", Text(items[i]))
 // 	})
 //
-// 	list := g.El("ul", lis...)
+// 	list := El("ul", lis...)
 func Map(length int, cb func(i int) Node) []Node {
 	var nodes []Node
 	for i := 0; i < length; i++ {
@@ -234,3 +234,16 @@ func Map(length int, cb func(i int) Node) []Node {
 	}
 	return nodes
 }
+
+// If condition is true, return the given Node. Otherwise, return nil.
+// This helper function is good for inlining elements conditionally.
+// Example:
+// 	El("div",
+//		If(showMessage, El("span", "You lost your hat.")),
+//	)
+func If(condition bool, n Node) Node {
+	if condition {
+		return n
+	}
+	return nil
+}
diff --git a/gomponents_test.go b/gomponents_test.go
index 26199c3..c88a796 100644
--- a/gomponents_test.go
+++ b/gomponents_test.go
@@ -207,3 +207,15 @@ func TestMap(t *testing.T) {
 		assert.Equal(t, `<ul><li>hat</li><li>partyhat</li><li>turtlehat</li></ul>`, list)
 	})
 }
+
+func TestIf(t *testing.T) {
+	t.Run("returns node if condition is true", func(t *testing.T) {
+		n := g.El("div", g.If(true, g.El("span")))
+		assert.Equal(t, "<div><span></span></div>", n)
+	})
+
+	t.Run("returns nil if condition is false", func(t *testing.T) {
+		n := g.El("div", g.If(false, g.El("span")))
+		assert.Equal(t, "<div></div>", n)
+	})
+}