Build a Chat App
Welcome to Web5, the magical land where Web2 and Web3 intertwine. My name is Alice. I am a wanderer in search of an application where I can send short-text messages to my best friend, Bob.
π Your mission
Build Dinger, a self-sovereign, modern day pager that allows users to send short text-based messages or "dings" to each other.
π οΈ Your toolkit
To build this app, you will wield the following technologies:
- React - A JavaScript library, your brush to paint user interfaces, craft reusable components, and manage the state of your creation.
- Next.js - A React metaframework, your compass to guide you through creating pages, managing routes, and managing server-side rendering.
- Web5.js - A Web5 JavaScript SDK, your key to creating decentralized applications, facilitating direct communication between users, and granting them sovereignty over their data and identity.
π Your reward
By the end of this journey, you will acquire a deeper understanding of peer-to-peer communication in a Web5 ecosystem.
If you're ready for the challenge, let's get started!
Level 1: Explore the starter codeβ
Good news! You don't have to start from scratch. There is a pre-built application that contains the user interface for Dinger. Right now, the functions in the code donβt do much. They just print messages to the console and donβt have any real actions. As you progress through the tutorial, you will add logic to the functions.
π Taskβ
To access the starter code, follow the instructions below or explore the project directly in CodeSandbox.
Note: If you don't have pnpm
installed, you can install it by running npm install -g pnpm
.
git clone https://github.com/TBD54566975/tbd-examples.git
cd tbd-examples/javascript/dinger-starter
pnpm install
pnpm start
Finished Dinger App
If youβd like to skip ahead and see the finished version of this tutorial, you can check out the running app on CodeSandbox.
You can also download and run the example by executing:
Note: If you don't have pnpm
installed, you can install it by running npm install -g pnpm
.
git clone https://github.com/TBD54566975/tbd-examples.git
cd tbd-examples/javascript/dinger
pnpm install
pnpm start
There is also a hosted example deployed at https://dinger-chat.vercel.app/
To fully interact with the web app, please click "Open in New Tab" as demonstrated in the GIF below.