The goal of this project is to create a decentralized and community driven MetaVerse style game.
This repo includes the front-end game in which users can play and interact with the game on the Polygon Network and off chain data.
Looking to help out? Read our contributing docs - https://github.com/sunflower-land/sunflower-land/blob/main/docs/CONTRIBUTING.md
By contributing you agree to our terms and services - https://docs.sunflower-land.com/support/terms-of-service
https://sunflower-land.com/play
Read the official docs/ litepaper here: docs.sunflower-land.com
Follow the official guide here: How to Play?
First Read the FAQ's here: FAQ's
Still not satisfied? Submit a support ticket here: Submit a ticket
Please add a new idea for the community to vote on, here: SFL Idea Portal
Firstly, you will need to clone the repo locally. Once you have it ready navigate into the directory and run the following commands:
npm install --global yarn
(if you don't have yarn installed)yarn install
cp .env.sample .env
yarn dev
yarn test
This runs a range of business logic unit tests in the repo.
The plan is to use react testing library to test some of the core user interactions as well.
We use xstate
to control the manage the user and session using a State Machine approach. This prevents our application from getting into invalid states and handles the use cases of switching accounts, networks, etc.
The primary states include:
- Connecting (connecting to MetaMask)
- Ready (Waiting for user input - Start)
- Signing (Sign a message to verify the account on the API)
- Authorising (Checking if a user has an account/farm)
- Unauthorised (when one of the above state transitions fails)
- Authorised (Play the game!)
The app uses vite for bundling and development purposes. You can set build specific configuration in vite.config.ts
Tailwind is our CSS tool of choice. It enables us to:
- Use utility based classes
- Consistent theming (view
tailwind.config.js
) - Perform CSS processing to minimize build sizes
Metadata is generated from markdown files.
To add new item:
- Create
{SFT id}.md
file inmetadata\markdown
folder - Add
{SFT id}.png
file topublic\erc1155
folder - Run
yarn metadata
- Assets: Images, Music, Branding and other Media
- Components: Reusable react components
- Lib: Utils, classes, machines and more.
- Features: Core domain concepts that have their own use cases/boundaries. Each feature (e.g. crops) has a similar nested structure of components, graphql & lib that are specific only to that feature.
👨💻 Developers - https://github.com/sunflower-land/sunflower-land/blob/main/docs/CONTRIBUTING.md
🧑🎨 Artists - https://github.com/sunflower-land/sunflower-land/blob/main/docs/ART_CONTRIBUTING.md
The previous version was used unethically on other Blockchains. The team is working on deciding the licence that will best suit our community. Until then, the code falls under No Licence and cannot be reused.
All media assets (images and music) are not available for use in commercial or private projects.
If you plan on using the repo's assets you must seek permission from the Intellectual property or licence holder. For artists wishing to extend the base asset pack, you must download the SunnySide asset pack listed in the Art contributing docs.