+
+### Game of Realms
+
+The first high-stakes contest will see participants compete for tiered membership to co-own the Gno.land blockchain. A series of complex technical and non-technical tasks will challenge contributors to create innovative patterns that push the chain to new limits. Start building the foundation for tomorrow through key smart contracts and other contributions that change our understanding of the world.
+
+
+
+[Join Game Of Realms](/game-of-realms)
+
+
+
+
+### Fund and Grants Program
+
+Are you a builder, tinkerer, or researcher? If you’re looking to create awesome dApps, tooling, infrastructure, or smart contract libraries on Gno.land, you can apply for a grant. The Gno.land Ecosystem Fund and Grants program provides financial contributions for individuals and teams to innovate on the platform.
+
+
+
+[More information here](https://github.com/gnolang/ecosystem-fund-grants)
+
+
+
+### Build with Gnolang
+
+- [Gno dev with CLI (soon)](#)
+- [Explore the Universe](/ecosystem)
+- [Test in the browser (soon)](#)
+- [About the Gnolang Language](/gnolang)
+- [Docs/ Tutorials](https://github.com/gnolang)
+- [Gno by example](https://gno-by-example.com/)
+- [Getting started video (soon)](#)
+
+
+//
+// ### Game of Realms
+//
+// The first high-stakes contest will see participants compete for tiered membership to co-own the Gno.land blockchain. A series of complex technical and non-technical tasks will challenge contributors to create innovative patterns that push the chain to new limits. Start building the foundation for tomorrow through key smart contracts and other contributions that change our understanding of the world.
+//
+//
+//
+// [Join Game Of Realms](/game-of-realms)
+//
+//
+//
+//
+// ### Fund and Grants Program
+//
+// Are you a builder, tinkerer, or researcher? If you’re looking to create awesome dApps, tooling, infrastructure, or smart contract libraries on Gno.land, you can apply for a grant. The Gno.land Ecosystem Fund and Grants program provides financial contributions for individuals and teams to innovate on the platform.
+//
+//
+//
+// [More information here](https://github.com/gnolang/ecosystem-fund-grants)
+//
+//
+//
+// ### Build with Gnolang
+//
+// - [Gno dev with CLI (soon)](#)
+// - [Explore the Universe](/ecosystem)
+// - [Test in the browser (soon)](#)
+// - [About the Gnolang Language](/gnolang)
+// - [Docs/ Tutorials](https://github.com/gnolang)
+// - [Gno by example](https://gno-by-example.com/)
+// - [Getting started video (soon)](#)
+//
+//
+//
+// ---
+//
+// ### Socials
+//
+// - ![Discord](static/img/ico-discord.svg) [Discord](https://discord.gg/S8nKUqwkPn)
+// - ![Twitter](static/img/ico-twitter.svg) [Twitter](https://twitter.com/_gnoland)
+// - ![Youtube](static/img/ico-youtube.svg) [Youtube](https://www.youtube.com/@_gnoland)
+// - ![Telegram](static/img/ico-telegram.svg) [Telegram](https://t.me/gnoland)
+// Gno is for Truth.
diff --git a/gno.land/cmd/gnoweb/pages/ABOUT.md b/examples/gno.land/r/gnoland/pages/page_about.gno
similarity index 73%
rename from gno.land/cmd/gnoweb/pages/ABOUT.md
rename to examples/gno.land/r/gnoland/pages/page_about.gno
index a5678a7349a..9aba4e39f76 100644
--- a/gno.land/cmd/gnoweb/pages/ABOUT.md
+++ b/examples/gno.land/r/gnoland/pages/page_about.gno
@@ -1,4 +1,10 @@
-# About Gno.land
+package gnopages
+
+func init() {
+ path := "about"
+ title := "Gno.land Is A Platform To Write Smart Contracts In Gnolang (Gno)"
+ // XXX: description := "On Gno.land, developers write smart contracts and other blockchain apps using Gnolang (Gno) without learning a language that’s exclusive to a single ecosystem."
+ body := `# About Gno.land
Gno.land is a platform to write smart contracts in Gnolang (Gno).
Using an interpreted version of the general-purpose programming language Golang (Go), developers can write smart contracts and other blockchain apps without having to learn a language that’s exclusive to a single ecosystem.
@@ -9,4 +15,6 @@ Proof of Contribution rewards contributors from technical and non-technical back
This consensus mechanism also achieves higher security with fewer validators, optimizing resources for a greener, more sustainable, and enduring blockchain ecosystem.
Any blockchain using Gnolang achieves succinctness, composability, expressivity, and completeness not found in any other smart contract platform.
-By observing a minimal structure, the design can endure over time and challenge the regime of information censorship we’re living in today.
+By observing a minimal structure, the design can endure over time and challenge the regime of information censorship we’re living in today.`
+ _ = b.NewPost("", path, title, body, nil)
+}
diff --git a/examples/gno.land/r/gnoland/pages/page_ecosystem.gno b/examples/gno.land/r/gnoland/pages/page_ecosystem.gno
new file mode 100644
index 00000000000..68969c44529
--- /dev/null
+++ b/examples/gno.land/r/gnoland/pages/page_ecosystem.gno
@@ -0,0 +1,35 @@
+package gnopages
+
+func init() {
+ var (
+ path = "ecosystem"
+ title = "Discover Gno.land Ecosystem Projects & Initiatives"
+ // XXX: description = "Dive further into the Gno.land ecosystem and discover the core infrastructure, projects, smart contracts, and tooling we’re building."
+ body = `# Gno Ecosystem
+
+## Gno.land Space
+
+For the best onboarding experience, head over to [Gno.land Space](https://www.gnoland.space/) open ecosystem. Here you can set up your Gno wallet, explore existing community-written Gno smart contracts (realms), and become part of our vibrant community by joining [Gno.land Discord](https://discord.com/invite/x76qK4ttHC).
+
+## Gno Studio (IDE)
+
+Gno IDE is a web-based application helping builders quickly spin up Gno realms and packages right on their browsers. Offering a smooth and intuitive UX for building on Gno, you’ll find multiple modes for customizability with all the features you’d expect from an IDE, such as auto compilation in the editor, debugging, and extensive testing capability.
+
+## Gnoscan
+
+Developed by the Onbloc team, Gnoscan is Gno.land’s blockchain explorer. Anyone can use Gnoscan to easily find information that resides on the Gno.land blockchain, such as wallet addresses, TX hashes, blocks, and contracts. Gnoscan makes our on-chain data easy to read and intuitive to discover. [Go to Gnoscan.](https://gnoscan.io/)
+
+## Adena
+
+Adena is a user-friendly non-custodial wallet for Gno.land. Open-source and developed by Onbloc, Adena currently powers all transactions on Gno.land, allowing gnomes to interact easily with the chain. With an emphasis on UX, Adena is built to handle millions of realms and tokens with a high-quality interface, support for NFTs and custom tokens, and seamless integration. [Get started here.](https://adena.app/)
+
+## Gnoswap
+
+Gnoswap is currently under development and led by the Onbloc team. Gnoswap will be the first DEX on Gno.land and is an automated market maker (AMM) protocol written in Gnolang that allows for permissionless token exchanges on the platform.
+
+## Gno.land Developer Portal
+
+Through the Gno.land Developer Portal, new developers can explore the exciting world of Gnolang (Gno), a novel programming language that powers the Gno.land blockchain. If you want to interact with Gno.land, start writing a realm, build a dApp, or even port a Solidity contract to a Gnolang realm, you’ll find the resources to [get started here](https://docs.onbloc.xyz/).`
+ )
+ _ = b.NewPost("", path, title, body, nil)
+}
diff --git a/examples/gno.land/r/gnoland/pages/page_events.gno b/examples/gno.land/r/gnoland/pages/page_events.gno
new file mode 100644
index 00000000000..18e7faeb3d3
--- /dev/null
+++ b/examples/gno.land/r/gnoland/pages/page_events.gno
@@ -0,0 +1,151 @@
+package gnopages
+
+func init() {
+ var (
+ path = "events"
+ title = "Gno.land Core Team Attends Industry Events & Meetups"
+ // XXX: description = "If you’re interested in learning more about Gno.land, you can join us at major blockchain industry events throughout the year either in person or virtually."
+ body = `# Events
+
+If you’re interested in building web3 with us, catch up with Gno.land in person at one of our industry events. We’re looking to connect with developers and like-minded thinkers who can contribute to the growth of our platform.
+
+---
+
+## Upcoming Events
+
+
+
+
+### EthCC
+
+- **Come Meet Us at our Booth**
+- Paris, July 17 - 20, 2023
+- Manfred Touron
+
+[Learn more](https://www.ethcc.io/)
+
+
+
+### GopherCon EU
+
+- **Come Meet Us at our Booth**
+- Berlin, July 26 - 29, 2023
+
+[Learn more](https://gophercon.eu/)
+
+
+
+
+
+### GopherCon US
+
+- **Come Meet Us at our Booth**
+- San Diego, September 26 - 29, 2023
+
+[Learn more](https://www.gophercon.com/)
+
+
+
+
+---
+
+## Past Events
+
+
+
+
+
+### Eth Seoul
+
+- **The Evolution of Smart Contracts: A Journey into Gno.land**
+- Seoul, June 3, 2023
+- Manfred Touron
+
+[Learn more](https://2023.ethseoul.org/)
+
+
+
+
+### BUIDL Asia
+
+- **Proof of Contribution in Gno.land**
+- Seoul, June 6, 2023
+- Manfred Touron
+
+[Learn more](https://www.buidl.asia/)
+
+
+
+
+### Game Developer Conference
+
+- **Side Event: Web3 Gaming Apps Powered by Gno**
+- San Francisco, Mach 23, 2023
+- Jae Kwon
+
+[Watch the talk](https://www.youtube.com/watch?v=IJ0xel8lr4c)
+
+
+
+
+### EthDenver
+
+- **Side Event: Discover Gno.land**
+- Denver, Feb 24 - Mar 5, 2023
+- Jae Kwon
+
+[Watch the talk](https://www.youtube.com/watch?v=IJ0xel8lr4c)
+
+
+
+
+### Istanbul Blockchain Week
+
+- Istanbul, Nov 14 - 17, 2022
+- Manfred Touron
+
+[Watch the talk](https://www.youtube.com/watch?v=JX0gdWT0Cg4)
+
+
+
+
+### Web Summit Buckle Up and Build with Cosmos
+
+- Lisbon, Nov 1 - 4, 2022
+- Manfred Touron
+
+
+
+### Berlin Blockchain Week Buckle Up and Build with Cosmos
+
+- Berlin, Sept 11 - 18, 2022
+
+[Watch the talk](https://www.youtube.com/watch?v=hCLErPgnavI)
+
+
+
`
+ )
+ _ = b.NewPost("", path, title, body, nil)
+}
diff --git a/examples/gno.land/r/gnoland/pages/page_gnolang.gno b/examples/gno.land/r/gnoland/pages/page_gnolang.gno
new file mode 100644
index 00000000000..f0c2bfe276d
--- /dev/null
+++ b/examples/gno.land/r/gnoland/pages/page_gnolang.gno
@@ -0,0 +1,43 @@
+package gnopages
+
+func init() {
+ var (
+ path = "gnolang"
+ title = "Gnolang (Gno) Is a Complete Language for Blockchain"
+ // XXX: description = "Gnolang (Gno) is an interpretation of the popular Golang (Go) language for blockchain created by Tendermint and Cosmos founder Jae Kwon."
+ body = `# About the Gnolang, the Gno Language
+
+[Gnolang](https://github.com/gnolang/gno/blob/master/LICENSE.md) (Gno) is an interpretation of the widely-used Golang (Go) programming language for blockchain created by Cosmos co-founder Jae Kwon in 2022 to mark a new era in smart contracting. Gno is ~99% identical to Go, so Go programmers can start coding in Gno right away, with a minimal learning curve. For example, Gno comes with blockchain-specific standard libraries, but any code that doesn’t use blockchain-specific logic can run in Go with minimal processing. Libraries that don’t make sense in the blockchain context, such as network or operating-system access, are not available in Gno. Otherwise, Gno loads and uses many standard libraries that power Go, so most of the parsing of the source code is the same.
+
+Under the hood, the Gno code is parsed into an abstract syntax tree (AST) and the AST itself is used in the interpreter, rather than bytecode as in many virtual machines such as Java, Python, or Wasm. This makes even the GnoVM accessible to any Go programmer. The novel design of the intuitive GnoVM interpreter allows Gno to freeze and resume the program by persisting and loading the entire memory state. Gno is deterministic, auto-persisted, and auto-Merkle-ized, allowing (smart contract) programs to be succinct, as the programmer doesn’t have to serialize and deserialize objects to persist them into a database (unlike programming applications with the Cosmos SDK).
+
+## How Gno Differs from Go
+
+![Gno and Go differences](static/img/gno-language/go-and-gno.jpg)
+
+The composable nature of Go/Gno allows for type-checked interactions between contracts, making Gno.land safer and more powerful, as well as operationally cheaper and faster. Smart contracts on Gno.land are light, simple, more focused, and easily interoperable—a network of interconnected contracts rather than siloed monoliths that limit interactions with other contracts.
+
+![Example of Gno code](static/img/gno-language/code-example.jpg)
+
+## Gno Inherits Go’s Built-in Security Features
+
+Go supports secure programming through exported/non-exported fields, enabling a “least-authority” design. It is easy to create objects and APIs that expose only what should be accessible to callers while hiding what should not be simply by the capitalization of letters, thus allowing a succinct representation of secure logic that can be called by multiple users.
+
+Another major advantage of Go is that the language comes with an ecosystem of great tooling, like the compiler and third-party tools that statically analyze code. Gno inherits these advantages from Go directly to create a smart contract programming language that provides embedding, composability, type-check safety, and garbage collection, helping developers to write secure code relying on the compiler, parser, and interpreter to give warning alerts for common mistakes.
+
+## Gno vs Solidity
+
+The most widely-adopted smart contract language today is Ethereum’s EVM-compatible Solidity. With bytecode built from the ground up and Turing complete, Solidity opened up a world of possibilities for decentralized applications (dApps) and there are currently more than 10 million contracts deployed on Ethereum. However, Solidity provides limited tooling and its EVM has a stack limit and computational inefficiencies.
+
+Solidity is designed for one purpose only (writing smart contracts) and is bound by the limitations of the EVM. In addition, developers have to learn several languages if they want to understand the whole stack or work across different ecosystems. Gno aspires to exceed Solidity on multiple fronts (and other smart contract languages like CosmWasm or Substrate) as every part of the stack is written in Gno. It’s easy for developers to understand the entire system just by studying a relatively small code base.
+
+## Gno Is Essential for the Wider Adoption of Web3
+
+Gno makes imports as easy as they are in web2 with runtime-based imports for seamless dependency flow comprehension, and support for complex structs, beyond primitive types. Gno is ultimately cost-effective as dependencies are loaded once, enabling remote function calls as local, and providing automatic and independent per-realm state persistence.
+
+Using Gno, developers can rapidly accelerate application development and adopt a modular structure by reusing and reassembling existing modules without building from scratch. They can embed one structure inside another in an intuitive way while preserving localism, and the language specification is simple, successfully balancing practicality and minimalism.
+
+The Go language is so well designed that the Gno smart contract system will become the new gold standard for smart contract development and other blockchain applications. As a programming language that is universally adopted, secure, composable, and complete, Gno is essential for the broader adoption of web3 and its sustainable growth.`
+ )
+ _ = b.NewPost("", path, title, body, nil)
+}
diff --git a/examples/gno.land/r/gnoland/pages/page_gor.gno b/examples/gno.land/r/gnoland/pages/page_gor.gno
new file mode 100644
index 00000000000..6c9e46b4062
--- /dev/null
+++ b/examples/gno.land/r/gnoland/pages/page_gor.gno
@@ -0,0 +1,215 @@
+package gnopages
+
+func init() {
+ var (
+ path = "gor"
+ title = "Game of Realms Content For The Best Contributors"
+ // XXX: description = "Game of Realms is the first high-stakes competition held in two phases to find the best contributors to the Gno.land platform with a 133,700 ATOM prize pool."
+ body = `# Game of Realms
+
+The worldwide competition to find the best contributors to Gno.land is currently in phase one – for advanced developers only.
+
+Once the necessary tools to start phase two are ready, we’ll open up the competition to newer devs and non-technical contributors.
+
+If you want to stack ATOM rewards and play a key role in the success of Gno.land and web3, read more about Game of Realms or open a [PR](https://github.com/gnolang/gno/) today.
+
+
+
+
+
+
+
+## Phase I. (ongoing)
+
+-
+
+-
+
+-
+
+
+
+
+## Phase II. (Locked)
+
+
+
+
+
+
+
+
+
+## Evaluation DAO
+
+This complex challenge seeks your skills in DAO development and implementation and is one of the most important challenges of phase one. The Evaluation DAO will ensure that contributions in Game of Realms and the Gno.land platform are fairly rewarded.
+
+
+
+
+
+
+
+
+
+
+
+
+Game of Realms participants and core contributors are still in discussions, proposing additional ideas, and seeing how the proposal for the Evaluation DAO evolves over time.
+
+
+
+
+
+
+
+See [GitHub issue 519](https://github.com/gnolang/gno/issues/519) for the most up-to-date discussion so far on how voting should work for the DAO, what the responsibilities are, how to join, etc.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+## Tutorials
+
+To progress to phase two of the competition, we need high-quality tutorials, guides, and documentation from phase one participants. Help to create materials that will onboard more contributors to Gno.land.
+
+
+
+
+
+
+
+
+
+
+
+
+How to create, present, and house the tutorials has been established with productive discussions between core contributors and external participants.
+
+
+
+
+
+
+
+We followed a collaborative approach to defining the scope of the work and creating a series of tutorials and videos, Gno by Example, to explain core concepts and show newcomers how to write in the Gno programming language. Gno docs and tutorials will be community-run so that anyone can contribute. Onbloc’s [developer portal](https://docs.onbloc.xyz/) is an excellent onramp to Gno.land currently. We will soon be releasing a documentation instance to house all tutorials.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+## Governance Module
+
+Can you define and implement a governance contract suite that rivals existing ones, such as the Cosmos Hub? Show us how! We’re looking for the fairest and most efficient governance solution possible.
+
+
+
+
+
+
+
+
+
+
+
+
+Game of Realms participants and core contributors have made significant progress teaming up to complete this challenge but discussions and additional ideas are still ongoing.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+## Register Now
+
+
+
+
+
+
+`
+ )
+ _ = b.NewPost("", path, title, body, nil)
+}
diff --git a/examples/gno.land/r/gnoland/pages/page_start.gno b/examples/gno.land/r/gnoland/pages/page_start.gno
new file mode 100644
index 00000000000..a36ec6e52b1
--- /dev/null
+++ b/examples/gno.land/r/gnoland/pages/page_start.gno
@@ -0,0 +1,21 @@
+package gnopages
+
+func init() {
+ path := "start"
+ title := "Getting Started with Gno"
+ // XXX: description := ""
+
+ // TODO: codegen to use README files here
+
+ /* TODO: port previous message: This is a demo of Gno smart contract programming. This document was
+ constructed by Gno onto a smart contract hosted on the data Realm
+ name ["gno.land/r/demo/boards"](https://gno.land/r/demo/boards/)
+ ([github](https://github.com/gnolang/gno/tree/master/examples/gno.land/r/demo/boards)).
+ */
+ body := `## Getting Started with Gno
+
+- [Install Gno Key](/r/demo/boards:testboard/5)
+- TODO: add more links
+`
+ _ = b.NewPost("", path, title, body, nil)
+}
diff --git a/examples/gno.land/r/gnoland/pages/page_testnets.gno b/examples/gno.land/r/gnoland/pages/page_testnets.gno
new file mode 100644
index 00000000000..b6c09ab71ee
--- /dev/null
+++ b/examples/gno.land/r/gnoland/pages/page_testnets.gno
@@ -0,0 +1,19 @@
+package gnopages
+
+func init() {
+ path := "testnets"
+ title := "Gno.land Testnets"
+ // XXX: description := """
+ body := `## Other testnets
+
+- **[staging.gno.land](https://staging.gno.land) (wiped every commit to master)**
+- _[test3.gno.land](https://test3.gno.land) (latest)_
+- _[test2.gno.land](https://test2.gno.land) (archive)_
+- _[test1.gno.land](https://test1.gno.land) (archive)_
+
+## Local devnet
+
+See CONTRIBUTING.md on GitHub.
+`
+ _ = b.NewPost("", path, title, body, nil)
+}
diff --git a/examples/gno.land/r/gnoland/pages/page_tokenomics.gno b/examples/gno.land/r/gnoland/pages/page_tokenomics.gno
new file mode 100644
index 00000000000..de899ae0a70
--- /dev/null
+++ b/examples/gno.land/r/gnoland/pages/page_tokenomics.gno
@@ -0,0 +1,11 @@
+package gnopages
+
+func init() {
+ var (
+ path = "tokenomics"
+ title = "Gno.land Tokenomics"
+ // XXX: description = """
+ body = `Lorem Ipsum`
+ )
+ _ = b.NewPost("", path, title, body, nil)
+}
diff --git a/examples/gno.land/r/gnoland/pages/pages.gno b/examples/gno.land/r/gnoland/pages/pages.gno
index 9ad5a212c95..6e1f117d1d5 100644
--- a/examples/gno.land/r/gnoland/pages/pages.gno
+++ b/examples/gno.land/r/gnoland/pages/pages.gno
@@ -4,18 +4,12 @@ import (
"gno.land/p/demo/blog"
)
-var b = &blog.Blog{
- Title: "Gnoland's Pages",
- Prefix: "/r/gnoland/pages:",
-}
+// TODO: switch from p/blog to p/pages
-func init() {
- _ = b.NewPost("", "game-of-realms", "Game of Realms", "Lorem Ipsum", nil)
- _ = b.NewPost("", "events", "Events", "Lorem Ipsum", nil)
- _ = b.NewPost("", "tokenomics", "Tokenomics", "Lorem Ipsum", nil)
- _ = b.NewPost("", "start", "Getting Started", "Lorem Ipsum", nil)
- _ = b.NewPost("", "about", "About Page", "Lorem Ipsum", nil)
- _ = b.NewPost("", "language", "About Gnolang, the Gno Language", "Lorem Ipsum", nil)
+var b = &blog.Blog{
+ Title: "Gnoland's Pages",
+ Prefix: "/r/gnoland/pages:",
+ NoBreadcrumb: true,
}
func Render(path string) string {
diff --git a/examples/gno.land/r/gnoland/pages/pages_test.gno b/examples/gno.land/r/gnoland/pages/pages_test.gno
index 1a43153e2c8..1389e5b5463 100644
--- a/examples/gno.land/r/gnoland/pages/pages_test.gno
+++ b/examples/gno.land/r/gnoland/pages/pages_test.gno
@@ -6,48 +6,42 @@ import (
"testing"
)
-func TestPackage(t *testing.T) {
- std.TestSetOrigCaller(std.Address("g1u7y667z64x2h7vc6fmpcprgey4ck233jaww9zq"))
-
- author := std.GetOrigCaller()
-
- // by default, lorem ipsum posts
- {
- got := Render("")
- expected := `
-# Gnoland's Pages
-
-
{{ template "footer" }}
- {{ template "js" }}
-
-
-
+ {{ template "js" .}}
{{- end -}}
diff --git a/gno.land/cmd/gnoweb/views/redirect.html b/gno.land/cmd/gnoweb/views/redirect.html
new file mode 100644
index 00000000000..6fe43a7138b
--- /dev/null
+++ b/gno.land/cmd/gnoweb/views/redirect.html
@@ -0,0 +1,16 @@
+{{- define "app" -}}
+
+
+
+
+
+
+
+ Redirecting to {{.Data.To}}
+
+
+ {{.Data.To}}
+ {{ template "analytics" .}}
+
+
+{{- end -}}
From 5e4572b36b10720379b59af64177faf4f08164e3 Mon Sep 17 00:00:00 2001
From: moul <94029+moul@users.noreply.github.com>
Date: Tue, 17 Oct 2023 23:48:50 +0200
Subject: [PATCH 10/21] chore: improve content, add page partner, make home
more focused
Signed-off-by: moul <94029+moul@users.noreply.github.com>
---
examples/gno.land/r/gnoland/home/home.gno | 150 +++++++++---------
.../gno.land/r/gnoland/home/home_filetest.gno | 61 +++----
.../gno.land/r/gnoland/pages/page_gor.gno | 20 ++-
.../r/gnoland/pages/page_partners.gno | 21 +++
.../gno.land/r/gnoland/pages/pages_test.gno | 2 +-
gno.land/cmd/gnoweb/main.go | 2 +
6 files changed, 140 insertions(+), 116 deletions(-)
create mode 100644 examples/gno.land/r/gnoland/pages/page_partners.gno
diff --git a/examples/gno.land/r/gnoland/home/home.gno b/examples/gno.land/r/gnoland/home/home.gno
index 2a30fb75d25..ba777d1dbcd 100644
--- a/examples/gno.land/r/gnoland/home/home.gno
+++ b/examples/gno.land/r/gnoland/home/home.gno
@@ -4,42 +4,30 @@ import "std"
var body = `# Welcome to Gno.land
----
-
-## An interpretation of the Golang (Go) programming language for advanced developers and intrepid pioneers to build succinct, composable smart contracts for social coordination.
+### An interpretation of the Golang (Go) programming language for advanced developers and intrepid pioneers to build succinct, composable smart contracts for social coordination.
If you’re concerned about information censorship and want to contribute to the #GnoWorldOrder, follow our socials to find out how.
Gno.land is in building mode. If you want to help lay the foundations of a fairer and freer world through innovative ideas and exceptional code, join us today.
-
-
-### Game of Realms
-
-The first high-stakes contest will see participants compete for tiered membership to co-own the Gno.land blockchain. A series of complex technical and non-technical tasks will challenge contributors to create innovative patterns that push the chain to new limits. Start building the foundation for tomorrow through key smart contracts and other contributions that change our understanding of the world.
-
-
-
-[Join Game Of Realms](/game-of-realms)
-
-
-
-
-### Fund and Grants Program
+---
-Are you a builder, tinkerer, or researcher? If you’re looking to create awesome dApps, tooling, infrastructure, or smart contract libraries on Gno.land, you can apply for a grant. The Gno.land Ecosystem Fund and Grants program provides financial contributions for individuals and teams to innovate on the platform.
+### WorxDAO
-
+TODO
-[More information here](https://github.com/gnolang/ecosystem-fund-grants)
+- A
+ - A1
+ - A1A
+ - A1B
+ - A2
+ - A3
+ - A3A
+ - A3A1
+- B
+- C
-
+---
@@ -47,11 +35,12 @@ Are you a builder, tinkerer, or researcher? If you’re looking to create awesom
### Learn about Gno.land
- [About](/about)
+- [GitHub](https://github.com/gnolang)
- [Subscribe](#subscribe)
- [Tokenomics (soon)](#)
- [Blog](/blog)
- [Events](/events)
-- [Partners (soon)](#)
+- [Partners, Fund, Grants](/partners)
@@ -82,66 +71,70 @@ Are you a builder, tinkerer, or researcher? If you’re looking to create awesom
-//
-// ### Game of Realms
-//
-// The first high-stakes contest will see participants compete for tiered membership to co-own the Gno.land blockchain. A series of complex technical and non-technical tasks will challenge contributors to create innovative patterns that push the chain to new limits. Start building the foundation for tomorrow through key smart contracts and other contributions that change our understanding of the world.
-//
-//
-//
-// ### Fund and Grants Program
-//
-// Are you a builder, tinkerer, or researcher? If you’re looking to create awesome dApps, tooling, infrastructure, or smart contract libraries on Gno.land, you can apply for a grant. The Gno.land Ecosystem Fund and Grants program provides financial contributions for individuals and teams to innovate on the platform.
-//
-//
-//
-// [More information here](https://github.com/gnolang/ecosystem-fund-grants)
-//
-//
//
//
//
@@ -52,6 +48,7 @@ func main() {
// ### Learn about Gno.land
//
// - [About](/about)
+// - [GitHub](https://github.com/gnolang)
// - [Subscribe](#subscribe)
// - [Tokenomics (soon)](#)
// - [Blog](/blog)
@@ -91,8 +88,12 @@ func main() {
//
// ### Socials
//
+// - Check out our [community projects](https://github.com/gnolang/awesome-gno).
// - ![Discord](static/img/ico-discord.svg) [Discord](https://discord.gg/S8nKUqwkPn)
// - ![Twitter](static/img/ico-twitter.svg) [Twitter](https://twitter.com/_gnoland)
// - ![Youtube](static/img/ico-youtube.svg) [Youtube](https://www.youtube.com/@_gnoland)
// - ![Telegram](static/img/ico-telegram.svg) [Telegram](https://t.me/gnoland)
+//
+// **This is a testnet.**
+// Package names are not guaranteed to be available for production.
// Gno is for Truth.
diff --git a/examples/gno.land/r/gnoland/pages/page_gor.gno b/examples/gno.land/r/gnoland/pages/page_gor.gno
index 6c9e46b4062..3a6bb022e09 100644
--- a/examples/gno.land/r/gnoland/pages/page_gor.gno
+++ b/examples/gno.land/r/gnoland/pages/page_gor.gno
@@ -1,13 +1,20 @@
package gnopages
func init() {
- var (
- path = "gor"
- title = "Game of Realms Content For The Best Contributors"
- // XXX: description = "Game of Realms is the first high-stakes competition held in two phases to find the best contributors to the Gno.land platform with a 133,700 ATOM prize pool."
- body = `# Game of Realms
+ path := "gor"
+ title := "Game of Realms Content For The Best Contributors"
+ // XXX: description := "Game of Realms is the first high-stakes competition held in two phases to find the best contributors to the Gno.land platform with a 133,700 ATOM prize pool."
+ body := `# Game of Realms
-The worldwide competition to find the best contributors to Gno.land is currently in phase one – for advanced developers only.
+
+
+### Game of Realms
+
+The first high-stakes contest will see participants compete for tiered membership to co-own the Gno.land blockchain. A series of complex technical and non-technical tasks will challenge contributors to create innovative patterns that push the chain to new limits. Start building the foundation for tomorrow through key smart contracts and other contributions that change our understanding of the world.
+
+
+
+The competition is currently in phase one – for advanced developers only.
Once the necessary tools to start phase two are ready, we’ll open up the competition to newer devs and non-technical contributors.
@@ -210,6 +217,5 @@ Game of Realms participants and core contributors have made significant progress
`
- )
_ = b.NewPost("", path, title, body, nil)
}
diff --git a/examples/gno.land/r/gnoland/pages/page_partners.gno b/examples/gno.land/r/gnoland/pages/page_partners.gno
new file mode 100644
index 00000000000..440302437fa
--- /dev/null
+++ b/examples/gno.land/r/gnoland/pages/page_partners.gno
@@ -0,0 +1,21 @@
+package gnopages
+
+func init() {
+ path := "partners"
+ title := "Partners"
+ // XXX: description := """
+ body := `## Partnerships
+
+### Fund and Grants Program
+
+Are you a builder, tinkerer, or researcher? If you’re looking to create awesome dApps, tooling, infrastructure, or smart contract libraries on Gno.land, you can apply for a grant. The Gno.land Ecosystem Fund and Grants program provides financial contributions for individuals and teams to innovate on the platform.
+
+
+
+[More information here](https://github.com/gnolang/ecosystem-fund-grants)
+
+
+`
+
+ _ = b.NewPost("", path, title, body, nil)
+}
diff --git a/examples/gno.land/r/gnoland/pages/pages_test.gno b/examples/gno.land/r/gnoland/pages/pages_test.gno
index 1389e5b5463..5a6fe84ad38 100644
--- a/examples/gno.land/r/gnoland/pages/pages_test.gno
+++ b/examples/gno.land/r/gnoland/pages/pages_test.gno
@@ -15,7 +15,7 @@ func TestHome(t *testing.T) {
"/r/gnoland/pages:p/start",
"/r/gnoland/pages:p/gor",
"/r/gnoland/pages:p/about",
- "/r/gnoland/pages:p/language",
+ "/r/gnoland/pages:p/gnolang",
}
for _, substring := range expectedSubtrings {
if !strings.Contains(got, substring) {
diff --git a/gno.land/cmd/gnoweb/main.go b/gno.land/cmd/gnoweb/main.go
index 3b9f6f5fec3..0d9398cb8e2 100644
--- a/gno.land/cmd/gnoweb/main.go
+++ b/gno.land/cmd/gnoweb/main.go
@@ -70,6 +70,7 @@ func makeApp() gotuna.App {
"/about": "/r/gnoland/pages:p/about",
"/gnolang": "/r/gnoland/pages:p/gnolang",
"/ecosystem": "/r/gnoland/pages:p/ecosystem",
+ "/partners": "/r/gnoland/pages:p/partners",
"/testnets": "/r/gnoland/pages:p/testnets",
"/start": "/r/gnoland/pages:p/start",
"/game-of-realms": "/r/gnoland/pages:p/gor", // XXX: replace with gor realm
@@ -83,6 +84,7 @@ func makeApp() gotuna.App {
"/r/demo/boards:gnolang/6": "/r/demo/boards:gnolang/3", // XXX: temporary
"/blog": "/r/gnoland/blog",
"/gor": "/game-of-realms",
+ "/grants": "/partners",
"/language": "/gnolang",
"/getting-started": "/start",
}
From a628e6ebb5928bcde663ff895920abb5cea783cf Mon Sep 17 00:00:00 2001
From: moul <94029+moul@users.noreply.github.com>
Date: Tue, 17 Oct 2023 20:44:14 -0400
Subject: [PATCH 11/21] chore: fixup
Signed-off-by: moul <94029+moul@users.noreply.github.com>
---
examples/gno.land/r/demo/boards/README.md | 149 ++++++++++++++++++++++
1 file changed, 149 insertions(+)
create mode 100644 examples/gno.land/r/demo/boards/README.md
diff --git a/examples/gno.land/r/demo/boards/README.md b/examples/gno.land/r/demo/boards/README.md
new file mode 100644
index 00000000000..2729df055b1
--- /dev/null
+++ b/examples/gno.land/r/demo/boards/README.md
@@ -0,0 +1,149 @@
+This is a demo of Gno smart contract programming. This document was
+constructed by Gno onto a smart contract hosted on the data Realm
+name ["gno.land/r/demo/boards"](https://gno.land/r/demo/boards/)
+([github](https://github.com/gnolang/gno/tree/master/examples/gno.land/r/demo/boards)).
+
+
+
+## Build `gnokey`, create your account, and interact with Gno.
+
+NOTE: Where you see `-remote localhost:26657` here, that flag can be replaced
+with `-remote test3.gno.land:36657` if you have $GNOT on the testnet.
+(To use the testnet, also replace `-chainid dev` with `-chainid testchain` .)
+
+### Build `gnokey` (and other tools).
+
+```bash
+git clone git@github.com:gnolang/gno.git
+cd gno/gno.land
+make build
+```
+
+### Generate a seed/mnemonic code.
+
+```bash
+./build/gnokey generate
+```
+
+NOTE: You can generate 24 words with any good bip39 generator.
+
+### Create a new account using your mnemonic.
+
+```bash
+./build/gnokey add -recover KEYNAME
+```
+
+NOTE: `KEYNAME` is your key identifier, and should be changed.
+
+### Verify that you can see your account locally.
+
+```bash
+./build/gnokey list
+```
+
+Take note of your `addr` which looks something like `g17sphqax3kasjptdkmuqvn740u8dhtx4kxl6ljf` .
+You will use this as your `ACCOUNT_ADDR`.
+
+## Interact with the blockchain.
+
+### Add $GNOT for your account.
+
+Before starting the `gnoland` node for the first time, your new account can be given $GNOT in the node genesis.
+Edit the file `gno.land/genesis/genesis_balances.txt` and add the following line (simlar to the others), using
+your `ACCOUNT_ADDR` and `KEYNAME`
+
+`ACCOUNT_ADDR=10000000000ugnot # @KEYNAME`
+
+### Alternative: Run a faucet to add $GNOT.
+
+Instead of editing `gno.land/genesis/genesis_balances.txt`, a more general solution (with more steps)
+is to run a local "faucet" and use the web browser to add $GNOT. (This can be done at any time.)
+See this page: https://github.com/gnolang/gno/blob/master/gno.land/cmd/gnofaucet/README.md
+
+### Start the `gnoland` node.
+
+```bash
+./build/gnoland start
+```
+
+NOTE: The node already has the "boards" realm.
+
+Leave this running in the terminal. In a new terminal, cd to the same folder `gno/gno.land` .
+
+### Get your current balance, account number, and sequence number.
+
+```bash
+./build/gnokey query auth/accounts/ACCOUNT_ADDR -remote localhost:26657
+```
+
+### Register a board username with a smart contract call.
+
+The `USERNAME` for posting can different than your `KEYNAME`. It is internally linked to your `ACCOUNT_ADDR`. It must be at least 6 characters, lowercase alphanumeric with underscore.
+
+```bash
+./build/gnokey maketx call -pkgpath "gno.land/r/demo/users" -func "Register" -args "" -args "USERNAME" -args "Profile description" -gas-fee "10000000ugnot" -gas-wanted "2000000" -send "200000000ugnot" -broadcast -chainid dev -remote 127.0.0.1:26657 KEYNAME
+```
+
+Interactive documentation: https://test3.gno.land/r/demo/users?help&__func=Register
+
+### Create a board with a smart contract call.
+
+```bash
+./build/gnokey maketx call -pkgpath "gno.land/r/demo/boards" -func "CreateBoard" -args "BOARDNAME" -gas-fee "1000000ugnot" -gas-wanted "10000000" -broadcast -chainid dev -remote localhost:26657 KEYNAME
+```
+
+Interactive documentation: https://test3.gno.land/r/demo/boards?help&__func=CreateBoard
+
+Next, query for the permanent board ID by querying (you need this to create a new post):
+
+```bash
+./build/gnokey query "vm/qeval" -data "gno.land/r/demo/boards
+GetBoardIDFromName(\"BOARDNAME\")" -remote localhost:26657
+```
+
+### Create a post of a board with a smart contract call.
+
+NOTE: If a board was created successfully, your SEQUENCE_NUMBER would have increased.
+
+```bash
+./build/gnokey maketx call -pkgpath "gno.land/r/demo/boards" -func "CreateThread" -args BOARD_ID -args "Hello gno.land" -args "Text of the post" -gas-fee 1000000ugnot -gas-wanted 2000000 -broadcast -chainid dev -remote localhost:26657 KEYNAME
+```
+
+Interactive documentation: https://test3.gno.land/r/demo/boards?help&__func=CreateThread
+
+### Create a comment to a post.
+
+```bash
+./build/gnokey maketx call -pkgpath "gno.land/r/demo/boards" -func "CreateReply" -args BOARD_ID -args "1" -args "1" -args "Nice to meet you too." -gas-fee 1000000ugnot -gas-wanted 2000000 -broadcast -chainid dev -remote localhost:26657 KEYNAME
+```
+
+Interactive documentation: https://test3.gno.land/r/demo/boards?help&__func=CreateReply
+
+```bash
+./build/gnokey query "vm/qrender" -data "gno.land/r/demo/boards
+BOARDNAME/1" -remote localhost:26657
+```
+
+### Render page with optional path expression.
+
+The contents of `https://gno.land/r/demo/boards:` and `https://gno.land/r/demo/boards:gnolang` are rendered by calling
+the `Render(path string)` function like so:
+
+```bash
+./build/gnokey query "vm/qrender" -data "gno.land/r/demo/boards
+gnolang"
+```
+## View the board in the browser.
+
+### Start the web server.
+
+```bash
+./build/gnoweb
+```
+
+This should print something like `Running on http://127.0.0.1:8888` . Leave this running in the terminal.
+
+### View in the browser
+
+In your browser, navigate to the printed address http://127.0.0.1:8888 .
+To see you post, click on the package `/r/demo/boards` .
From edeaeb24f426056e391aa6aa8d24add6416faf08 Mon Sep 17 00:00:00 2001
From: moul <94029+moul@users.noreply.github.com>
Date: Tue, 17 Oct 2023 23:12:04 -0400
Subject: [PATCH 12/21] chore: refactor homepage
Signed-off-by: moul <94029+moul@users.noreply.github.com>
---
examples/gno.land/p/demo/ui/ui.gno | 44 ++-
examples/gno.land/r/gnoland/home/home.gno | 304 ++++++++++--------
.../gno.land/r/gnoland/home/home_filetest.gno | 118 +++++--
3 files changed, 305 insertions(+), 161 deletions(-)
diff --git a/examples/gno.land/p/demo/ui/ui.gno b/examples/gno.land/p/demo/ui/ui.gno
index efa185914a0..59e9403a025 100644
--- a/examples/gno.land/p/demo/ui/ui.gno
+++ b/examples/gno.land/p/demo/ui/ui.gno
@@ -1,6 +1,9 @@
package ui
-import "strings"
+import (
+ "strconv"
+ "strings"
+)
type DOM struct {
// metadata
@@ -56,6 +59,17 @@ func (dom DOM) String() string {
return output
}
+type Jumbotron []DomStringer
+
+func (j Jumbotron) String(dom DOM) string {
+ output := `
-
----
-
-### Socials
-
-- Check out our [community projects](https://github.com/gnolang/awesome-gno).
-- ![Discord](static/img/ico-discord.svg) [Discord](https://discord.gg/S8nKUqwkPn)
-- ![Twitter](static/img/ico-twitter.svg) [Twitter](https://twitter.com/_gnoland)
-- ![Youtube](static/img/ico-youtube.svg) [Youtube](https://www.youtube.com/@_gnoland)
-- ![Telegram](static/img/ico-telegram.svg) [Telegram](https://t.me/gnoland)
-
-**This is a testnet.**
-Package names are not guaranteed to be available for production.
-`
-
-var adminAddr std.Address = std.Address("")
-
-func Render(_ string) string {
- // highest level == highest responsibility
- // teams are responsible for components they don't owne
- // flag : realm maintainers VS facilitators
- // teams
- // committee of trustees to create the directory
- // each directory is a name, has a parent and have groups
- // homepage team - blocks aggregating events
-
- /*`
- # Directory
-
- * gno.land (owned by group)
- *
- * gnovm
- * gnolang (language)
- * gnovm
- - current challenges / concerns / issues
- * tm2
- * amino
- *
-
- ## Contributors
- ``*/
-
- // XXX: dynamic content: contributions
- // XXX:
- // XXX: community curated picks
- // XXX:
- body += "\n\n" + randomBanner()
-
- return body
-}
-
-func randomBanner() string {
- // not sure to keep this...
- banners := []string{
- "Gno is for Truth.",
- "Gno is for Social Coordination.",
- "Gno is _not only_ for DeFi.",
+
`),
}
- height := std.GetHeight()
- idx := int(height) % len(banners)
- return banners[idx]
}
diff --git a/examples/gno.land/r/gnoland/home/home_filetest.gno b/examples/gno.land/r/gnoland/home/home_filetest.gno
index 43e831e79c6..9032277ae38 100644
--- a/examples/gno.land/r/gnoland/home/home_filetest.gno
+++ b/examples/gno.land/r/gnoland/home/home_filetest.gno
@@ -11,36 +11,85 @@ func main() {
//
// ### An interpretation of the Golang (Go) programming language for advanced developers and intrepid pioneers to build succinct, composable smart contracts for social coordination.
//
+//
// If you’re concerned about information censorship and want to contribute to the #GnoWorldOrder, follow our socials to find out how.
//
+//
// Gno.land is in building mode. If you want to help lay the foundations of a fairer and freer world through innovative ideas and exceptional code, join us today.
//
+//