Skip to content

Starter template

Background

This documents whether we should build a dApp starter template.

Today for dApp developments there are great starter template like [Scaffold-ETH2] or ecosystems specific ones like create-filecoin-app, create-nillion-app. They do a great job onboarding new develoeprs..

  • ScaffoldETH is great and designed to make it simple for beginners to start from scratch. We like every library they use, and of course the team and community.
  • It rightfully uses a opionated techstack with modular compatabile extensions.
  • Our focus is to optimize and secure production build, to make wagmi, rainbowkit optional and adapt to various styling methods, with a differernt vision of optimizing the library for LLM to iterate the sites.

Meanwhile, “vibe coding” is getting popular, one can bootstrap a project by prompting LLM such as replit, v0 or bolt.new

Here by “scaffold” we refers to creating working, customizable project, “generator” for modules generating code for required frameworks and features, incrementally

Composability of scaffold tool is not a new problem (refer to appendix), We believe what could improve the situation are 1) unix-style customizable, replaceable, modules/receipes with minimized dependencies and 2) enhancing AI dev tools’s ability to test against desired combination of techstack.

In our context where we expect to incrementally add and customize components similiar to shadcn, we aims to create lightweight scaffold template which then alias to execute some importantgeist add per wizard input, and expect user to follow up the rest

Our take

Generally, we optimize for LLM to bootstrap and iterate incrementally.

Sepcfically, compare to Scaffold-ETH2

  1. We offer framework-agnostic, different falvoured recipes and components, where developer/LLM can copy-paste subset of components as standalone application, supporting easy customization as in shadcn.

We want to be agnostic regarding

  • tooling e.g. yarn is not a must
  • FE framework e.g. solid, astro supoprt
  • dependencies
  1. We don’t target inexperienced developers. More experienced ones might prefer debugging with explorer over wrapper components for read / write contract useScaffoldReadContract

Appendix

Ecosystems Comparison

EcosystemAS-IS packagesNPM Wk DlNotes on tooling
generalwagmi160kabitype, viem. use @noble under the hood
general@noble/curves1.8Mother utils like secp256k1 (330k)
Baseonchainkit8k
Stark@starknet-react/core2k
XMTPreact-xmtp2k
EAS@ethereum-attestation-service/eas-sdk3k
ENSensjs, react
Minao1js2kzkapp-cli
MUD@latticexyz/react3k
permissionlesspermissionless27k
Superchain

Wagmi