A casual game based on the Stroop effect with React Native

Stroopwafel to add realtime and multiplayer features to your apps. If you’re curious, check out this essay to learn more about “why Instant”.

You can see Stroopwafel live in the app store.

Quickstart

If you haven’t already, you’ll need to install Expo Go.

After that go ahead and clone the repo and install the dependencies. From your terminal run

# Clone the repo
git clone ...

# change into the directory
cd ...

# Install dependencies
npm i

Now you’ll need to log in and head over to your dashboard on Instant and generate a new APP_ID. Open up src/App.js and replace the placeholder value to your new ID.

From there you should be ready to load up dev! From the project root

make dev

Huzzah!

Building the project

If you want to try making a development build we recommend you set up Expo Application Services.

Edit app.json and eas.json to configure your own credentials. We’ve left the configuration we used for Stroopwafel as a reference.

Android

We tested on iOS only but getting Stroopwafel working in the play store should be straightforward. We’ll update this repo with Android instructions in the future.

Reference

Below is a non-exhaustive breakdown of each part of the app.

App.js

This is root component of the app. Here we

  • init Instant
  • Create a user and persist them to Instant on first load
  • Load up the rest of the App

Navigator.js

We use React-Navigiation to manage navigating across all the screens in Stroopwafel. You can conceptually categorize each screen as follows:

  • Main: This is the first screen we render when opening the app
  • Single Player
    • Singleplayer — This is the actual game screen
    • GameOverSingleplayer — This is the game over screen for singleplayer
  • Mulitplayer
    • JoinRoom — Simple screen that prompts users for a room code to join a lobby
    • WaitingRoom — This is the lobby screen before a game beings
    • Mulitplayer — This is the game screen for mulitplayer
    • GameOverMulitplayer — This is the game over screen for mulitplayer
  • Misc
    • HowToPlay — This screen explains how to play Stroopwafel
    • Settings — Another simple screen, allows users to change their handles.

Components/scenes

This is the meat and potatoes of the app. You’ll notice most of the code is front-end focused. Querying and mutating data is done through Instant and is very light-weight. Looks through these components to see different examples of InstaQL and InstaML.

Here’s the data model for the app

users {
  handle: string,
  highScore: int,
  created_at: string,
}

rooms {
  code: string?,
  currentGameId: uuid,
  readyIds: [uuid],
  kickedIds: [uuid],
  hostId: uuid,
  created_at: string,
  deleted_at: string,
  :has_many users
}

games {
  status: "IN_PROGRESS" | "COMPLETED",
  colors: [[text: string, color: string]]
  playerIds: [uuid],
  created_at: string,
  :belongs_to rooms
}

points {
  userId: uuid,
  val: int,
  :belongs_to games
}

Some components of note:

  • Main.js — Shows how to create a new room and associate it with a user.
  • GameOverSingleplayer.js — Shows how to update a user’s highscore
  • WaitingRoom.js — Shows to update multiple models in one transaction. Also shows how to fetch a specific model and a relation with useQuery
  • Multiplayer.js — Shows how to fetch multiple relations for a namespace. Also shows how to easily update users scores. What’s especially nice about this is you can just update a user’s score, and Instant takes care of updating everyone else through the power of useQuery

Note: Currently Instant does not support permissions. Once permissions is released, will integrate them into Stroopwafel

Say hello!

Do you want to build your own apps with Instant? If so, hopefully this repo has been helpful for you! We love hearing feedback and what folks want to build. Come say hello on our discord!

GitHub

View Github