Baby Gender Reveal Vote is an interactive web application that transforms traditional gender reveal parties into engaging events. This open-source project allows friends and family to participate in predicting the baby's gender through a beautiful, real-time voting system.
- 🎯 Perfect for Modern Celebrations: Ideal for both in-person and virtual baby showers
- ⚡ Real-time Experience: Instant vote updates and live results
- 🌍 Inclusive Design: Multi-language support and mobile-responsive interface
- 🔒 Secure: One vote per user system with admin controls
- 🎨 Beautiful Interface: Engaging animations and themed design
- 💻 Easy Setup: Simple installation process with detailed documentation
- Virtual Baby Showers
- In-person Gender Reveal Parties
- Family Gatherings
- Social Media Live Events
- Baby Shower Games
- Gender Prediction Contests
Features • Screenshots • Installation • Report Bug • Request Feature
- About
- Features
- Screenshots
- Technical Details
- Installation
- Firebase Setup Steps
- Available Scripts
- Verification Steps
- Common Setup Issues
- Development Tips
- Usage Guide
- Admin Guide
- Contributing
- Troubleshooting
- License
- React.js
- Firebase
- TailwindCSS
- Framer Motion
- Simple and intuitive gender selection interface
- Beautiful animated backgrounds with themed icons
- Real-time vote tracking with instant updates
- Multiple language support for international users
- Mobile-responsive design for all devices
- Secure one-vote-per-user system
- Interactive selection cards with visual feedback
- Vote confirmation system
- Live vote counting and percentage calculation
- Dynamic result updates without page refresh
- Beautiful bar chart visualization with animations
- Leading prediction indicator with emoji support
- Total participation counter
- Percentage breakdowns for each gender
- Visual indicators for voting trends
- Export results functionality
- Complete game reset functionality
- Manual vote adjustments for both genders
- Screen visibility controls for results/voting
- Game state management (Started/Paused/Ended)
- Individual voter reset option
- Real-time vote monitoring
- Data backup and restore options
- Custom vote count adjustments
- Engaging vote confirmation screens
- Interactive waiting room for results
- Clear instruction panels
- Vote submission confirmations
- Reset for next voter capability
- Confetti celebrations for voting
- Animated transitions between screens
- Error handling with user-friendly messages
Welcome screen with multi-language support and simple navigation
Gender selection interface with intuitive design and visual feedback
The application uses Firebase Realtime Database with the following structure:
{
"gameState": {
"test": {
"message": "Test connection successful",
"timestamp": "2024-11-10T19:14:34.613Z"
},
"manualAdjustments": {
"boy": 0,
"girl": 0
},
"results": {
"showGameStarted": true,
"showResultPage": true,
"showVotingScreen": true
},
"userVotes": {
"06f26ecf-8ca2-4794-8de7-335878e17ad3": {},
"08f433e0-c054-47a7-a9bb-79d0dca0ec35": {}
// Additional user vote entries...
}
}
}
- gameState: Root node containing all game-related data
- test: Connection testing information
- manualAdjustments: Admin controls for vote adjustments
boy
: Manual adjustment count for boy votesgirl
: Manual adjustment count for girl votes
- results: Display control flags
showGameStarted
: Controls game start visibilityshowResultPage
: Controls result page visibilityshowVotingScreen
: Controls voting screen visibility
- userVotes: Collection of individual user votes using UUID keys
- Frontend: React.js with Vite for blazing-fast development
- Styling: TailwindCSS for responsive design
- State Management: React Context API
- Animations: Framer Motion
- Real-time Updates: WebSocket integration
- Icons: Custom SVG components
- Testing: Jest and React Testing Library
- Node.js v14.0.0 or higher
- npm v6.0.0 or higher
- Modern web browser with WebSocket support
- Minimum 512MB RAM
- Screen resolution: 320px minimum width
-
Clone the Repository
git clone https://github.com/rakshitbharat/open-source-baby-shower-game.git cd baby-shower-exit-poll-voting-app/source
-
Install Bun (if not already installed)
curl -fsSL https://bun.sh/install | bash
-
Install Dependencies
bun install
This will generate the
bun.lockb
file for your environment. -
Environment Setup
cp .env.example .env
-
Configure Firebase
Visit the Firebase Console and:
- Create a new project
- Go to Project Settings > General
- Scroll to "Your apps" and click the web icon (</>)
- Register your app and copy the config
-
Configure the
.env
fileFill in your
.env
file with the Firebase configuration:# Firebase Configuration VITE_FIREBASE_API_KEY=abc123xyz789... VITE_FIREBASE_AUTH_DOMAIN=your-app.firebaseapp.com VITE_FIREBASE_DATABASE_URL=https://your-app-default-rtdb.firebaseio.com VITE_FIREBASE_PROJECT_ID=your-app VITE_FIREBASE_STORAGE_BUCKET=your-app.appspot.com VITE_FIREBASE_MESSAGING_SENDER_ID=123456789 VITE_FIREBASE_APP_ID=1:123456789:web:abc123... # App Configuration VITE_REDIRECT_URL=https://your-domain.com/
-
Start the Development Server
bun start # Starts dev server at http://localhost:5173
bun start
- Start the development serverbun run build
- Build for productionbun run preview
- Preview production buildbun run clean
- Remove node_modulesbun run clean:cache
- Clear Bun cache
Setting up Firebase for your project involves creating a Firebase project, configuring various services like Authentication and Realtime Database, and integrating them into your application.
-
Go to Firebase Console
- Sign in with your Google account, or create one if you haven't already.
-
Click on "Add Project"
- Enter your project name (e.g., "Baby Gender Reveal Vote").
- (Optional) Edit the Project ID if you want a custom one.
- Check the box to agree to the Firebase terms.
- Click "Continue".
-
Google Analytics Setup (Optional)
- You can enable Google Analytics for your project or skip it.
- If you choose to enable it, select your Analytics account or create a new one.
- Click "Continue".
-
Click "Create Project"
- Wait for Firebase to set up your new project.
-
Click "Continue" to navigate to your Firebase project console.
-
Add an App to Your Project
- In the Firebase Console, find the "Your apps" section.
- Click the
</>
Web icon to add Firebase to your web app. - Register your app by providing a nickname (e.g., "Voting App").
- Check the box for "Also set up Firebase Hosting" if you plan to use it later (optional).
- Click "Register app".
-
Copy Firebase SDK Snippet
- You will receive the Firebase SDK configuration (a code snippet containing Firebase keys).
- This information will be used to configure the Firebase SDK in your app.
-
Modify your
.env
File- Use the provided Firebase configuration to populate your
.env
file:
VITE_FIREBASE_API_KEY=<your-api-key> VITE_FIREBASE_AUTH_DOMAIN=<your-auth-domain> VITE_FIREBASE_DATABASE_URL=<your-database-url> VITE_FIREBASE_PROJECT_ID=<your-project-id> VITE_FIREBASE_STORAGE_BUCKET=<your-storage-bucket> VITE_FIREBASE_MESSAGING_SENDER_ID=<your-sender-id> VITE_FIREBASE_APP_ID=<your-app-id>
- Use the provided Firebase configuration to populate your
-
Navigate to Realtime Database in Firebase Console
- Click on "Realtime Database" in the left sidebar.
-
Create a New Database
- Click "Create Database".
- Choose "Start in Test Mode" to allow all reads and writes (be sure to change this in production).
- Click "Next" and then "Done".
-
Configure Database Rules
- Go to the "Rules" tab in the Realtime Database.
- Replace the default rules with:
{ "rules": { ".read": true, ".write": true, "gameState": { ".read": true, ".write": true, "vote": { ".read": true, ".write": true }, "results": { ".read": true, ".write": true } } } }
- Click "Publish" to apply the rules.
-
Navigate to Authentication in Firebase Console
- Click on "Authentication" in the sidebar.
-
Set Up Sign-In Method
- Go to the "Sign-in method" tab.
- Enable "Email/Password" by toggling it on and then click "Save".
-
Test Firebase Connection in Your App
- Run your app locally using
bun start
or the equivalent command. - Open the browser's development console (usually with F12 or right-click and Inspect).
- Look for a message confirming a successful Firebase connection.
- Run your app locally using
-
Submit a Test Vote
- Use your application's voting feature to test that data is correctly written to the Realtime Database.
-
Check if the app runs:
bun start
-
Verify Firebase connection:
- Open browser console
- Look for "Firebase Connected" message
- Try submitting a test vote
-
Firebase Connection Error
- Double-check all Firebase environment variables
- Ensure database rules are set correctly
- Verify project ID matches
-
Bun Installation Issues
# Try cleaning cache bun clean:cache bun install
-
Port Conflicts
# Use a different port VITE_PORT=3000 bun start
- Use
bun start
for hot-reload development - Check console for Firebase connection status
- Test on multiple browsers for compatibility
- Use React DevTools for debugging
baby shower, gender reveal, voting app, baby gender prediction, virtual baby shower, gender reveal party, real-time voting, baby shower games, interactive baby shower, gender reveal ideas
Follow me for more awesome projects!