From 92d5aaf12ff55f441869394b30005f24c6fdd4f7 Mon Sep 17 00:00:00 2001 From: moul <94029+moul@users.noreply.github.com> Date: Tue, 19 Nov 2024 15:47:24 +0100 Subject: [PATCH 1/7] feat: add r/docs/home Signed-off-by: moul <94029+moul@users.noreply.github.com> --- examples/gno.land/r/docs/home/gno.mod | 1 + examples/gno.land/r/docs/home/home.gno | 12 ++++++++++++ 2 files changed, 13 insertions(+) create mode 100644 examples/gno.land/r/docs/home/gno.mod create mode 100644 examples/gno.land/r/docs/home/home.gno diff --git a/examples/gno.land/r/docs/home/gno.mod b/examples/gno.land/r/docs/home/gno.mod new file mode 100644 index 00000000000..b9f8d060f75 --- /dev/null +++ b/examples/gno.land/r/docs/home/gno.mod @@ -0,0 +1 @@ +module gno.land/r/docs/home diff --git a/examples/gno.land/r/docs/home/home.gno b/examples/gno.land/r/docs/home/home.gno new file mode 100644 index 00000000000..3d67f645a03 --- /dev/null +++ b/examples/gno.land/r/docs/home/home.gno @@ -0,0 +1,12 @@ +package home + +func Render(_ string) string { + return `# Gno Examples Documentation + +Welcome to the Gno examples documentation index. +Explore various examples to learn more about Gno. + +- [Hello World](/r/docs/hello) - A simple introductory example. + +` +} From fd460e4fed1310985c8db32d8fcd745063b29e4a Mon Sep 17 00:00:00 2001 From: moul <94029+moul@users.noreply.github.com> Date: Tue, 19 Nov 2024 15:49:12 +0100 Subject: [PATCH 2/7] chore: fixup Signed-off-by: moul <94029+moul@users.noreply.github.com> --- examples/gno.land/r/demo/hello_world/gno.mod | 1 - examples/gno.land/r/docs/hello_world/gno.mod | 1 + examples/gno.land/r/{demo => docs}/hello_world/hello.gno | 0 examples/gno.land/r/{demo => docs}/hello_world/hello_test.gno | 0 examples/gno.land/r/docs/home/home.gno | 2 +- 5 files changed, 2 insertions(+), 2 deletions(-) delete mode 100644 examples/gno.land/r/demo/hello_world/gno.mod create mode 100644 examples/gno.land/r/docs/hello_world/gno.mod rename examples/gno.land/r/{demo => docs}/hello_world/hello.gno (100%) rename examples/gno.land/r/{demo => docs}/hello_world/hello_test.gno (100%) diff --git a/examples/gno.land/r/demo/hello_world/gno.mod b/examples/gno.land/r/demo/hello_world/gno.mod deleted file mode 100644 index 9561cd4f077..00000000000 --- a/examples/gno.land/r/demo/hello_world/gno.mod +++ /dev/null @@ -1 +0,0 @@ -module gno.land/r/demo/hello_world diff --git a/examples/gno.land/r/docs/hello_world/gno.mod b/examples/gno.land/r/docs/hello_world/gno.mod new file mode 100644 index 00000000000..647795d3406 --- /dev/null +++ b/examples/gno.land/r/docs/hello_world/gno.mod @@ -0,0 +1 @@ +module gno.land/r/docs/hello_world diff --git a/examples/gno.land/r/demo/hello_world/hello.gno b/examples/gno.land/r/docs/hello_world/hello.gno similarity index 100% rename from examples/gno.land/r/demo/hello_world/hello.gno rename to examples/gno.land/r/docs/hello_world/hello.gno diff --git a/examples/gno.land/r/demo/hello_world/hello_test.gno b/examples/gno.land/r/docs/hello_world/hello_test.gno similarity index 100% rename from examples/gno.land/r/demo/hello_world/hello_test.gno rename to examples/gno.land/r/docs/hello_world/hello_test.gno diff --git a/examples/gno.land/r/docs/home/home.gno b/examples/gno.land/r/docs/home/home.gno index 3d67f645a03..648c22426fd 100644 --- a/examples/gno.land/r/docs/home/home.gno +++ b/examples/gno.land/r/docs/home/home.gno @@ -6,7 +6,7 @@ func Render(_ string) string { Welcome to the Gno examples documentation index. Explore various examples to learn more about Gno. -- [Hello World](/r/docs/hello) - A simple introductory example. +- [Hello World](/r/docs/hello_world) - A simple introductory example. ` } From 7ef0f26405fffc3ce155f0bfef555a9352c9cb6e Mon Sep 17 00:00:00 2001 From: moul <94029+moul@users.noreply.github.com> Date: Tue, 19 Nov 2024 15:55:12 +0100 Subject: [PATCH 3/7] chore: fixup Signed-off-by: moul <94029+moul@users.noreply.github.com> --- examples/gno.land/r/docs/home/home.gno | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/examples/gno.land/r/docs/home/home.gno b/examples/gno.land/r/docs/home/home.gno index 648c22426fd..f62cb76cdcf 100644 --- a/examples/gno.land/r/docs/home/home.gno +++ b/examples/gno.land/r/docs/home/home.gno @@ -6,7 +6,14 @@ func Render(_ string) string { Welcome to the Gno examples documentation index. Explore various examples to learn more about Gno. + +## Examples + - [Hello World](/r/docs/hello_world) - A simple introductory example. + +## Other resources + +- [Official documentation](https://github.com/gnolang/gno/tree/master/docs) ` } From b9bce29701c075ddbc69b57227758b7c92f667b5 Mon Sep 17 00:00:00 2001 From: moul <94029+moul@users.noreply.github.com> Date: Tue, 19 Nov 2024 17:04:53 +0100 Subject: [PATCH 4/7] chore: fixup Signed-off-by: moul <94029+moul@users.noreply.github.com> --- examples/gno.land/r/docs/hello/gno.mod | 1 + examples/gno.land/r/docs/hello/hello.gno | 11 +++++++++++ .../docs/{hello_world => hello}/hello_test.gno | 2 +- examples/gno.land/r/docs/hello_world/gno.mod | 1 - examples/gno.land/r/docs/hello_world/hello.gno | 17 ----------------- 5 files changed, 13 insertions(+), 19 deletions(-) create mode 100644 examples/gno.land/r/docs/hello/gno.mod create mode 100644 examples/gno.land/r/docs/hello/hello.gno rename examples/gno.land/r/docs/{hello_world => hello}/hello_test.gno (93%) delete mode 100644 examples/gno.land/r/docs/hello_world/gno.mod delete mode 100644 examples/gno.land/r/docs/hello_world/hello.gno diff --git a/examples/gno.land/r/docs/hello/gno.mod b/examples/gno.land/r/docs/hello/gno.mod new file mode 100644 index 00000000000..25ddf30051f --- /dev/null +++ b/examples/gno.land/r/docs/hello/gno.mod @@ -0,0 +1 @@ +module gno.land/r/docs/hello diff --git a/examples/gno.land/r/docs/hello/hello.gno b/examples/gno.land/r/docs/hello/hello.gno new file mode 100644 index 00000000000..e881c155cdd --- /dev/null +++ b/examples/gno.land/r/docs/hello/hello.gno @@ -0,0 +1,11 @@ +// Package hello_world demonstrates basic usage of Render(). +// Try adding `:World` at the end of the URL, like `.../hello:World`. +package hello + +// Render outputs a greeting. It customizes the message based on the provided path. +func Render(path string) string { + if path == "" { + return "# Hello, 世界!" + } + return "# Hello, " + path + "!" +} diff --git a/examples/gno.land/r/docs/hello_world/hello_test.gno b/examples/gno.land/r/docs/hello/hello_test.gno similarity index 93% rename from examples/gno.land/r/docs/hello_world/hello_test.gno rename to examples/gno.land/r/docs/hello/hello_test.gno index 4c3d86c556a..8159fb1341c 100644 --- a/examples/gno.land/r/docs/hello_world/hello_test.gno +++ b/examples/gno.land/r/docs/hello/hello_test.gno @@ -1,4 +1,4 @@ -package hello_world +package hello import ( "testing" diff --git a/examples/gno.land/r/docs/hello_world/gno.mod b/examples/gno.land/r/docs/hello_world/gno.mod deleted file mode 100644 index 647795d3406..00000000000 --- a/examples/gno.land/r/docs/hello_world/gno.mod +++ /dev/null @@ -1 +0,0 @@ -module gno.land/r/docs/hello_world diff --git a/examples/gno.land/r/docs/hello_world/hello.gno b/examples/gno.land/r/docs/hello_world/hello.gno deleted file mode 100644 index 312520de44d..00000000000 --- a/examples/gno.land/r/docs/hello_world/hello.gno +++ /dev/null @@ -1,17 +0,0 @@ -// Package hello_world demonstrates the usage of the Render() function. -// Render() can be called via the vm/qrender ABCI query off-chain to -// retrieve realm state or any other custom data defined by the realm -// developer. The vm/qrender query allows for additional data to be -// passed in with the call, which can be utilized as the path argument -// to the Render() function. This allows developers to create different -// "renders" of their realms depending on the data which is passed in, -// such as pagination, admin dashboards, and more. -package hello_world - -func Render(path string) string { - if path == "" { - return "# Hello, 世界!" - } - - return "# Hello, " + path + "!" -} From 68bd519edb97c956df31b345e7e9b4f1ac2e8428 Mon Sep 17 00:00:00 2001 From: moul <94029+moul@users.noreply.github.com> Date: Tue, 19 Nov 2024 17:21:47 +0100 Subject: [PATCH 5/7] chore: fixup Signed-off-by: moul <94029+moul@users.noreply.github.com> --- .../gno.land/r/docs/avl_pager/avl_pager.gno | 40 ++++++++++++++ .../r/docs/avl_pager/avl_pager_test.gno | 55 +++++++++++++++++++ examples/gno.land/r/docs/avl_pager/gno.mod | 1 + examples/gno.land/r/docs/home/home.gno | 8 +-- examples/gno.land/r/docs/home/home_test.gno | 22 ++++++++ 5 files changed, 122 insertions(+), 4 deletions(-) create mode 100644 examples/gno.land/r/docs/avl_pager/avl_pager.gno create mode 100644 examples/gno.land/r/docs/avl_pager/avl_pager_test.gno create mode 100644 examples/gno.land/r/docs/avl_pager/gno.mod create mode 100644 examples/gno.land/r/docs/home/home_test.gno diff --git a/examples/gno.land/r/docs/avl_pager/avl_pager.gno b/examples/gno.land/r/docs/avl_pager/avl_pager.gno new file mode 100644 index 00000000000..75807b71981 --- /dev/null +++ b/examples/gno.land/r/docs/avl_pager/avl_pager.gno @@ -0,0 +1,40 @@ +package avl_pager + +import ( + "strconv" + + "gno.land/p/demo/avl" + "gno.land/p/demo/avl/pager" +) + +// Tree instance for 100 items +var tree *avl.Tree + +// Initialize a tree with 100 items. +func init() { + tree = avl.NewTree() + for i := 1; i <= 100; i++ { + key := "Item" + strconv.Itoa(i) + tree.Set(key, "Value of "+key) + } +} + +// Render paginated content based on the given URL path. +// URL format: `...?page=&size=` (default is page 1 and size 10). +func Render(path string) string { + p := pager.NewPager(tree, 10) // Default page size is 10 + page := p.MustGetPageByPath(path) + + // Header and pagination info + result := "# Paginated Items\n" + result += "Page " + strconv.Itoa(page.PageNumber) + " of " + strconv.Itoa(page.TotalPages) + "\n\n" + result += page.Selector() + "\n\n" + + // Display items on the current page + for _, item := range page.Items { + result += "- " + item.Key + ": " + item.Value.(string) + "\n" + } + + result += "\n" + page.Selector() // Repeat selector for ease of navigation + return result +} diff --git a/examples/gno.land/r/docs/avl_pager/avl_pager_test.gno b/examples/gno.land/r/docs/avl_pager/avl_pager_test.gno new file mode 100644 index 00000000000..1ffc9a0c3ba --- /dev/null +++ b/examples/gno.land/r/docs/avl_pager/avl_pager_test.gno @@ -0,0 +1,55 @@ +package avl_pager + +import ( + "testing" +) + +func TestRender(t *testing.T) { + // Test default Render output (first page) + output := Render("") + expected := `# Paginated Items +Page 1 of 10 + +**1** | [2](?page=2) | [3](?page=3) | … | [10](?page=10) + +- Item1: Value of Item1 +- Item10: Value of Item10 +- Item100: Value of Item100 +- Item11: Value of Item11 +- Item12: Value of Item12 +- Item13: Value of Item13 +- Item14: Value of Item14 +- Item15: Value of Item15 +- Item16: Value of Item16 +- Item17: Value of Item17 + +**1** | [2](?page=2) | [3](?page=3) | … | [10](?page=10)` + if output != expected { + t.Errorf("Render(\"\") failed, got:\n%s", output) + } +} + +func TestRender_page2(t *testing.T) { + // Test Render output for a custom page (page 2) + output := Render("?page=2&size=10") + expected := `# Paginated Items +Page 2 of 10 + +[1](?page=1) | **2** | [3](?page=3) | [4](?page=4) | … | [10](?page=10) + +- Item18: Value of Item18 +- Item19: Value of Item19 +- Item2: Value of Item2 +- Item20: Value of Item20 +- Item21: Value of Item21 +- Item22: Value of Item22 +- Item23: Value of Item23 +- Item24: Value of Item24 +- Item25: Value of Item25 +- Item26: Value of Item26 + +[1](?page=1) | **2** | [3](?page=3) | [4](?page=4) | … | [10](?page=10)` + if output != expected { + t.Errorf("Render(\"\") failed, got:\n%s", output) + } +} diff --git a/examples/gno.land/r/docs/avl_pager/gno.mod b/examples/gno.land/r/docs/avl_pager/gno.mod new file mode 100644 index 00000000000..bc7214f7bc1 --- /dev/null +++ b/examples/gno.land/r/docs/avl_pager/gno.mod @@ -0,0 +1 @@ +module gno.land/r/docs/avl_pager diff --git a/examples/gno.land/r/docs/home/home.gno b/examples/gno.land/r/docs/home/home.gno index f62cb76cdcf..7bc619eade2 100644 --- a/examples/gno.land/r/docs/home/home.gno +++ b/examples/gno.land/r/docs/home/home.gno @@ -4,13 +4,13 @@ func Render(_ string) string { return `# Gno Examples Documentation Welcome to the Gno examples documentation index. -Explore various examples to learn more about Gno. - +Explore various examples to learn more about Gno functionality and usage. ## Examples -- [Hello World](/r/docs/hello_world) - A simple introductory example. - +- [Hello World](/r/docs/hello) - A simple introductory example. +- [AVL Pager](/r/docs/avl_pager) - Paginate through AVL tree items. +- ... ## Other resources diff --git a/examples/gno.land/r/docs/home/home_test.gno b/examples/gno.land/r/docs/home/home_test.gno new file mode 100644 index 00000000000..98dc999e005 --- /dev/null +++ b/examples/gno.land/r/docs/home/home_test.gno @@ -0,0 +1,22 @@ +package home + +import ( + "strings" + "testing" +) + +func TestRenderHome(t *testing.T) { + output := Render("") + + // Check for the presence of key sections + if !contains(output, "# Gno Examples Documentation") { + t.Errorf("Render output is missing the title.") + } + if !contains(output, "Official documentation") { + t.Errorf("Render output is missing the official documentation link.") + } +} + +func contains(s, substr string) bool { + return strings.Index(s, substr) >= 0 +} From 85b0439a92cc463e3095fab778f3a28fb191c354 Mon Sep 17 00:00:00 2001 From: moul <94029+moul@users.noreply.github.com> Date: Tue, 19 Nov 2024 17:48:57 +0100 Subject: [PATCH 6/7] chore: fixup Signed-off-by: moul <94029+moul@users.noreply.github.com> --- examples/gno.land/r/docs/avl_pager/gno.mod | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/examples/gno.land/r/docs/avl_pager/gno.mod b/examples/gno.land/r/docs/avl_pager/gno.mod index bc7214f7bc1..0d05b24bcd0 100644 --- a/examples/gno.land/r/docs/avl_pager/gno.mod +++ b/examples/gno.land/r/docs/avl_pager/gno.mod @@ -1 +1,6 @@ module gno.land/r/docs/avl_pager + +require ( + gno.land/p/demo/avl v0.0.0-latest + gno.land/p/demo/avl/pager v0.0.0-latest +) From ba3ff33644e486e7c8840c26d88011b2562850a2 Mon Sep 17 00:00:00 2001 From: moul <94029+moul@users.noreply.github.com> Date: Tue, 19 Nov 2024 21:15:24 +0100 Subject: [PATCH 7/7] chore: fixup Signed-off-by: moul <94029+moul@users.noreply.github.com> --- examples/gno.land/r/docs/add/add.gno | 42 ++++++++++++++++++++++ examples/gno.land/r/docs/add/add_test.gno | 44 +++++++++++++++++++++++ examples/gno.land/r/docs/add/gno.mod | 3 ++ examples/gno.land/r/docs/home/home.gno | 1 + 4 files changed, 90 insertions(+) create mode 100644 examples/gno.land/r/docs/add/add.gno create mode 100644 examples/gno.land/r/docs/add/add_test.gno create mode 100644 examples/gno.land/r/docs/add/gno.mod diff --git a/examples/gno.land/r/docs/add/add.gno b/examples/gno.land/r/docs/add/add.gno new file mode 100644 index 00000000000..ffc8f9c6877 --- /dev/null +++ b/examples/gno.land/r/docs/add/add.gno @@ -0,0 +1,42 @@ +package add + +import ( + "strconv" + "time" + + "gno.land/p/moul/txlink" +) + +// Global variables to store the current number and last update timestamp +var ( + number int + lastUpdate time.Time +) + +// Add function to update the number and timestamp +func Add(n int) { + number += n + lastUpdate = time.Now() +} + +// Render displays the current number value, last update timestamp, and a link to call Add with 42 +func Render(path string) string { + // Display the current number and formatted last update time + result := "# Add Example\n\n" + result += "Current Number: " + strconv.Itoa(number) + "\n\n" + result += "Last Updated: " + formatTimestamp(lastUpdate) + "\n\n" + + // Generate a transaction link to call Add with 42 as the default parameter + txLink := txlink.URL("Add", "n", "42") + result += "[Increase Number](" + txLink + ")\n" + + return result +} + +// Helper function to format the timestamp for readability +func formatTimestamp(timestamp time.Time) string { + if timestamp.IsZero() { + return "Never" + } + return timestamp.Format("2006-01-02 15:04:05") +} diff --git a/examples/gno.land/r/docs/add/add_test.gno b/examples/gno.land/r/docs/add/add_test.gno new file mode 100644 index 00000000000..8994b895f7e --- /dev/null +++ b/examples/gno.land/r/docs/add/add_test.gno @@ -0,0 +1,44 @@ +package add + +import ( + "testing" +) + +func TestRenderAndAdd(t *testing.T) { + // Initial Render output + output := Render("") + expected := `# Add Example + +Current Number: 0 + +Last Updated: Never + +[Increase Number](/r/docs/add$help&func=Add&n=42) +` + if output != expected { + t.Errorf("Initial Render failed, got:\n%s", output) + } + + // Call Add with a value of 10 + Add(10) + + // Call Add again with a value of -5 + Add(-5) + + // Render after two Add calls + finalOutput := Render("") + + // Initial Render output + output = Render("") + expected = `# Add Example + +Current Number: 5 + +Last Updated: 2009-02-13 23:31:30 + +[Increase Number](/r/docs/add$help&func=Add&n=42) +` + if output != expected { + t.Errorf("Final Render failed, got:\n%s", output) + } +} diff --git a/examples/gno.land/r/docs/add/gno.mod b/examples/gno.land/r/docs/add/gno.mod new file mode 100644 index 00000000000..a66c63e0910 --- /dev/null +++ b/examples/gno.land/r/docs/add/gno.mod @@ -0,0 +1,3 @@ +module gno.land/r/docs/add + +require gno.land/p/moul/txlink v0.0.0-latest diff --git a/examples/gno.land/r/docs/home/home.gno b/examples/gno.land/r/docs/home/home.gno index 7bc619eade2..2c581019380 100644 --- a/examples/gno.land/r/docs/home/home.gno +++ b/examples/gno.land/r/docs/home/home.gno @@ -9,6 +9,7 @@ Explore various examples to learn more about Gno functionality and usage. ## Examples - [Hello World](/r/docs/hello) - A simple introductory example. +- [Add](/r/docs/add) - An interactive example to update a number with transactions. - [AVL Pager](/r/docs/avl_pager) - Paginate through AVL tree items. - ...