data:image/s3,"s3://crabby-images/8c150/8c1506286fa6a38d137842daa30a1af2c321912e" alt="Logo"
A web Plinko game inspired by Stake.com's Plinko game.
Play now 👉 https://plinko-web-game.netlify.app/
data:image/s3,"s3://crabby-images/734f5/734f5090a5a221e23f124c5fd2e4bcb5d6db3fca" alt=""
Plinko is a classic game where the player drops a ball in a multi-row pin pyramid, where the ball bounces randomly until it reaches the payout bins at the bottom.
This project is a replication of Stake.com's Plinko game, created using Svelte, Tailwind CSS, and matter-js. This website is a fun personal project to learn Svelte, and it is not affiliated with Stake.com in any way. I don't encourage gambling, so that's why I created a free-to-play version of the game.
Please do NOT send me emails or invitations asking me to implement a Plinko game for your company or personal portfolio. This project is for personal hobby only. It is NOT a promotion, and I will IGNORE any freelance invitations 🙏.
Please fork this project on your own if you want to build on top of it.
- 🤑 100% free to play, add money at any time (
not another crypto scam) - 🤖 Manual and auto-bet modes
- 📊 Real-time live stats
- 📱 Responsive design
The biggest limitation is that this project calculates the outcome on the client-side, so we cannot pre-determine the outcome before ball drop, nor force the ball to drop to a specific pin.
This is because this project uses matter-js as the physics engine. This engine runs on client-side, so the outcome is unknown until the ball reaches the bottom. This is different from Stake.com's implementation, where they calculate the outcome in a back-end server, then drop the ball to the determined pin.
Due to the physics engine's unpredictability, the actual average return value may be higher than the expected value (sometimes positive return). This is problematic for real-money gambling, since casinos make money by having a house advantage, where the expected return is always less than 1. This could be fixed by adjusting the bin payouts, but I stick to the original Stake.com's payout table for simplicity.
Note
Requires Node.js 20 or later.
-
Install pnpm version 9 or later
-
Clone this repository
-
Install dependencies
pnpm install
-
Start the development server
pnpm dev
The entire site is statically generated using @sveltejs/adapter-static.
-
Generate a static build
pnpm build
-
Preview the build site
pnpm preview
For unit tests, run:
pnpm test:unit
For end-to-end tests powered by Playwright:
-
Build for production
pnpm build
-
Run the tests
# Run in UI mode (recommended when writing tests) pnpm test:e2e:ui # Alternatively, run in headless mode pnpm test:e2e
A hidden page is only available in local dev environment to benchmark the payout probabilities and expected values. I used this page to tune the parameters of the matter-js physics engine and control the expected payout.
To visit this page, visit the below URL after starting the development server with pnpm dev
:
http://localhost:5173/benchmark
This project uses Netlify for deployment. To trigger a production deployment, create a commit with message starting with chore(release)
in the main
branch.
Mobile:
Manual Mode | Auto Mode |
---|---|
![]() |
![]() |