The 2022 is over, was a big year for me including the amazing Hackathon and Impact events in June. Since I started to work with the Neptune platform I wanted to create a game, so finally here is the idea: a bingo developed with P9 and Redis.
When the user access the first time to the application can create a new room. In this process a structure containing the room data will be saved in cache (IndexedDB).
data:image/s3,"s3://crabby-images/24dff/24dffbfc444fbde8c2599c8c2e7704a97ad8334f" alt="Create Room Dialog"
In the header bar we have the room/user data and three buttons that enables you to:
- turn on/off the music;
- share the room link to other users;
- exit from the room.
Below we have:
- users online box;
- new number box where the host has the button for get new ones;
- bingo overview.
data:image/s3,"s3://crabby-images/80988/80988f830e1f5034b7695c11fec74060bd5096c3" alt="Bingo Overview"
In order to join in the room the host will send the link got from the button on the header menu to the other users. Example:
http://localhost:8080/app/jd_bingo?room=JDBINGO2023
Then the user can enter the username and join.
data:image/s3,"s3://crabby-images/5d104/5d104b01790a6521471f2896c6fe272d3e567cd4" alt="Join in the Room Dialog"
The user interface is similar to the host one, in addition a random bingo ticket will be generated.
data:image/s3,"s3://crabby-images/5eb92/5eb925320b6df2c3883cbe34ac98097032344cf3" alt="User Interface"
First of all I installed a Redis server on a Linux machine, then used the corresponding URI under System Settings > Database (In-memory database). In the Events section of the cockpit I created the sendNewNumber event.
data:image/s3,"s3://crabby-images/25200/25200da8124764ca18ad0c27bf7d73c56cf23f79" alt="Redis Planet 9 Settings"
In the App Designer I created the neptune.events.Trigger and neptune.events.Listener elements, assigning the corresponding event in the attributes panel.
data:image/s3,"s3://crabby-images/f85c9/f85c914127302c6c3ea0feb2794e7256e6909968" alt="App Designer Events Elements"
In the press event of the "Get New Number" button I generated a random number from 1 to 90 and then called the trigger function passing the new int as a parameter. In this way the host will send the new number to the other users connected.
let newNumber = getNewNumber();
textNewNumber.setText(newNumber);
tableBingoHost.getModel().refresh(true);
triggersendNewNumberTrigger({number: newNumber});
In the action event of the sendNewNumberListener element the new number is received and the tables are updated.
if (!appContext.isHost) {
ModelData.Add(GtBingoNumbers, { number: data.number });
setCacheGtBingoNumbers();
textNewNumber.setText(data.number);
tableBingoHostMini.getModel().refresh(true);
tableBingoUser.getModel().refresh(true);
}
When the game starts the host get new numbers. The first user to get all 15 numbers in their ticket win the game.
I created a GIF (it may require some time to load):
View GIFUsing Redis in P9 applications has a huge potential, I want to give a big thank you to the engineering team and everyone else involved in this release.
Wish you all a Happy New Year!