Developer MultiGroup Çekiliş Arkadaşın is a web application for managing and organizing team giveaways, promoting engagement and fun within teams! There is a stage logic which is determined before the giveaway starts, so that every level unlocks in the specified time.
- Login / Register with Supabase Auth
- Stage-1: Choose the person which you will buy a present to using a giveaway spinner.
- Stage-2: Upload the present you have bought to the system when the stage unlocks.
- Stage-3: Play a game of Who Bought This Present ? as the last stage, don't forget to check your score from the scoreboard page for more surprises :)
- Next.js: Used for both frontend and backend development of the site.
- Vercel: For deployment of the project to the web.
- Supabase: Preference of provider for user authentication and database management.
- Tailwind CSS: Utility-first CSS framework for responsive and customizable UI.
We are using Supabase as our main storage - database - authentication provider for this project, so you firstly should create an account.
As the first step after creating account, we need to create an organization which will hold your project
and a project which will hold your data (storage - db - auth),
Now you are ready to create the tables that will hold your user data, matches and present photo URL's. Here is the schema for the database tables:
To create these tables, you can directly copy and paste the following query to SQL Editor which can be found in your sidebar:
-- Hold the user related calues
create table users (
id uuid primary key default uuid_generate_v4(), -- Current User ID
name text, -- Name of the current user
surname text, -- Surname of the current user
photo_url text, -- Public URL to users profile picture
points int4, -- Points gained from the game stage
username text, -- Username of the current user
email text, -- E-Mail of the current user
has_match bool, -- Whether someone has this user as a match in the mathces table
game_played bool -- Whether the user has played the game already
);
-- Matches tablosu
create table matches (
id uuid primary key default uuid_generate_v4(), -- Current User ID
matched_to text -- ID of the matched user
);
-- Presents tablosu
create table presents (
id text primary key, -- Current User ID
photo_url text -- Public URL to the photo of the present this user has bought
);
Supabase Storage will hold our user's profile pictures and the photos of the presents they have bought, so we need to initialize a storage bucket named images
and some sub-folders inside that storage bucket with names presents
and users
. You can access storage bucket creation in your sidebar's
📂 images /
├── 📂 presents/
└── 📂 users/
It is enough for you to create the directories correctly, the application will handle the rest of the work.
If you don't want your recently registered users to get an automatic e-mail from Supabase Auth for E-Mail verification, you can toggle the following setting in the Authentication tab of your sidebar:
You only need two environment variables to run the project correctly, your Supabase URL and Supabase Key. You can get this values from the following page:
After getting these values, (assuming you already forked and cloned this project to your local machine, if not check out run the project section) create a .env
file at the root of your project and populate it like the following:
NEXT_PUBLIC_SUPABASE_URL=your_supabase_url
NEXT_PUBLIC_SUPABASE_KEY=your_supabase_key
-
Clone the Repository: Clone the repository to your local machine.
git clone https://github.com/your-username/repository-name.git cd repository-name
-
Install Dependencies: Install the required dependencies.
npm install
-
Start the Development Server: Run the project in development mode.
npm run dev
You can change the background and logos both on the user form and loading screen easily, you only need to change the contents of the following folder while keeping the file names as they are.
📂 public /
└── 📂 images/
└── 📂 constants/
├── background.png
├── loading_logo.png
└── logo.png
To change the look, title or time of a stage you can simply edit the stages array in the following directory
📂 src /
└── 📂 data/
└── stages.ts
Example Stage Object:
{
"index": 1, // Takes values 1, 2 and 3
"name": "Eşleşme", // name of the stage displayed on StageCard component
"start_date": "2024-12-15T22:30:00+03:00", // Determines when the stage unlocks, accepts any time-zone in this format
"image": "/images/stages/1.png" // Path to the stage image shown on StageCard component
}
You don't need to edit the source URL for the stage image, rather you can just upload a new image with the same name to the following directory, as in the organization identity section above.
📂 public /
└── 📂 images/
└── 📂 stages/
├── 1.png
├── 2.png
└── 3.png
We are open for any kind contribution you are interested in, follow these steps to help us:
Fork this repository to your account and clone it to your local machine with the following command:
git clone https://github.com/yourusername/project-name.git
cd project-name
git checkout -b feature/your-feature
# or
git checkout -b fix/bug-name
Code your features/fixes and have fun :)
git status
This shows your changed files
# Stage all changes
git add .
# or stage for specific files
git add filename.js
git commit -m "Add: new login page"
# or
git commit -m "Fix: navigation bar responsiveness"
git push origin feature/your-feature
Go to GitHub and create a Pull Request to this repository