Skip to content

FandomFusion: A MERN platform to create, share, and explore lists of favorite anime, games, and movies with fellow fans. 🌟

Notifications You must be signed in to change notification settings

kenma-w/FandomFusion-Frontend

Β 
Β 

Repository files navigation

FandomFusion-Frontend

Welcome to FandomFusion – your gateway to exploring, curating, and sharing the worlds you love most! Whether you're an anime aficionado, a gaming guru, or a movie maniac, this project is all about celebrating your fandoms and connecting with others who share your passion.

πŸ“š Table of Contents

πŸ“ Summary

FandomFusion is another social media, where you can connect with people who has same taste like you, let it be animes, movies, and even videogames (yes, we hear you).

What will this app do? It will include a home feed, where you will be recommended various medias according to your followers, what they have suggested or recommended. Then user will be able to add friend, recommend any media, write a post and flaunt your profile.

Various media will also be rated according to the global critics, and user will also be able to add their own rating and a note to remind of how great/bad it was. (yeah, we forget sometimes lol)

🌐 Features

  • Search Across Public APIs: Dive into your favorite universes! Search for anime, games, and movies using integrated public APIs. Powered by RAWG, Jikan, and TMDB, FandomFusion ensures you’re always up-to-date with the latest trends.

  • Custom List Creation: Craft your ultimate fan lists. Whether it’s top anime battles, iconic game soundtracks, or unforgettable movie twists, create personalized collections and rate each item like the true connoisseur you are. Share your lists with fellow fans and spread the love!

  • Social Interaction: Connect and collaborate with fellow superfans. Follow others to keep up with their curated lists, chat directly on the platform, and build a community around your shared fandoms. Let’s unite the fandom universe!

  • Dynamic and Responsive User Interface: FandomFusion’s sleek, modern design looks stunning across all your devices, so you can enjoy exploring your fandoms wherever you are.

  • Home Page Highlights:

    • Discover what’s trending now in anime, games, and movies with real-time updates.
    • Explore curated recommendations designed to help you uncover hidden gems.
  • Top Picks of All Time:

    • Browse all-time greats from every corner of fandom culture. From top-rated anime to groundbreaking games and legendary movies, find what truly defines each medium.
    • Filter by genre, year, or ratings for a tailored experience.
  • Comprehensive Search Filters: Zero in on exactly what you’re looking for with filters like genre, release date, rating, and popularity.

  • User Profiles: Show off your fandom cred! Display your activity, curated lists, and follower stats. Explore other users’ profiles to find inspiration or your next binge-worthy series.

⚑ Tech Stack

  • Frontend: React.js + Vite (with TailwindCSS, without TypeScript)
  • APIs:

πŸ“¦ Dependencies

To bring this fandom experience to life, you’ll need npm or yarn installed.

πŸ› οΈ How To Setup

  1. Make sure you have an active internet connection – we’re diving deep into fandoms, after all!

  2. Fork this repository to your GitHub account.

  3. Clone your forked repository:

    git clone <forked-repo-link>
  4. Navigate into the project directory:

    cd FandomFusion-Frontend
  5. Install all necessary dependencies (make sure npm or yarn is configured for proxy if on college proxy, lookup here):

    npm install
  6. Set up your environment variables by creating a .env file in the root directory. Use .env.example as your guide.

  7. Start the development server:

    npm run dev
  8. You’re ready to explore! Access the frontend application on localhost:5173.

Note

Commands like git clone and npm install will not work if you have proxy enabled, also doing other network required tasks will not so try setting up proxy for that interface first! (sadly gaming can't be resolved)

Tip

To change port number for the developement of this project for mac users. Kindly refer to this article: https://blog.stackademic.com/how-to-change-the-default-port-number-in-react-react-tips-1a957b54759e

Figma

First Update the designs and wireframes in this Figma File before coding and bringing it to life.

This is an important step before pushing the final code.

Tip

Figma app or even website might not work if SOCKS proxy is set, make sure to disable SOCKS proxy before working with figma :)

πŸ”— Reference Links

πŸ—ΊοΈ Starters

πŸš€ React

🎨 Tailwind CSS

Useful Links from Backend

Tools

πŸ“ Directory Structure

.
β”œβ”€β”€ 🧾 package.json
β”œβ”€β”€ 🧾 package-lock.json
β”œβ”€β”€ 🧾 .env.example
β”œβ”€β”€  ℹ️  README.md
β”œβ”€β”€ πŸ“„ index.html
β”œβ”€β”€ πŸ“„ eslint.config.js
β”œβ”€β”€ πŸ“„ vite.config.js
β”œβ”€β”€ πŸ“ public
β”‚   └── πŸ–ΌοΈ favicon.ico
└── πŸ“ src
    β”œβ”€β”€ πŸ“ assets
    β”‚Β Β  └──  πŸ“ images
    β”œβ”€β”€ πŸ“ components
    β”‚       └── πŸ“„ SignUp.jsx
    β”œβ”€β”€ πŸ“ pages
    β”‚       └── πŸ“„ Home.jsx
    β”œβ”€β”€ πŸ“ services(api)
    β”œβ”€β”€ πŸ“ utils
    β”œβ”€β”€ πŸ“ hooks
    β”œβ”€β”€ πŸ“ routers
    β”‚   └── πŸ“„ AppRouter.jsx
    β”œβ”€β”€ πŸ“„ App.jsx
    β”œβ”€β”€πŸ“„ main.jsx
    β”œβ”€β”€ πŸ“„ index.css
    └── πŸ“„ App.css

Note

Adding new files? Make sure to add them here too – let’s keep it tidy and helpful for new contributors.

πŸ‘† Claim an Issue

Comment on the issue to claim it. If there’s no activity on your claim after two days, it may be reassigned to another contributor. Stuck? Ask for help on our Discord channel – no fan gets left behind!

  • Don’t forget to make your entry in the CONTRIBUTORS file before submitting your PR.

πŸ’» Communication

Building fandom magic together means staying connected. Whether you’re brainstorming new features or have a question, reach out on our Discord channel. We’re here to help, and we can’t wait to hear your ideas!

πŸ“‹ Contribution Guidelines

Some important points to remember before pushing the code

  1. Make sure you have Prettier installed, can be installed as an extension in most IDEs and Code Editors.
  2. Make the code and directory structure well organized like it was.
  3. Add suitable comments in the code, for better readability of the code, and do not make any change in the code which was not included in the issue.
  4. Properly create your commit message, and add screenshots for better clarity. Also try to include a screen recording.

Caution

Failure to follow these guidelines might result in a temporary ban!

Some general guidelines

We’re passionate about fostering a friendly and welcoming environment for all contributors. Let’s focus on what matters most – our shared love for fandoms and great code quality.

  • People first: Be respectful and patient. We’re all here because of our shared passion.
  • Commit with purpose: Name your commits meaningfully and reference relevant issue numbers. Follow the PR template.
  • Show, don’t just tell: Screenshots or short videos can make reviews smoother.
  • Avoid duplicate PRs: If necessary, comment on the older PR with the follow-up PR number and close the obsolete one.
  • Three-day rule: PRs inactive for more than three days may be closed.

Let’s create something amazing together. 🌟

🀝 Mentor

  • Bhavya Gupta (aka Gamin8ing)
    Discord handler and an all-time gamer
    GitHub: Gamin8ing
    Discord: gamin8ing

πŸ’ͺ Thanks To All Contributors

Every contributor is a part of our fandom family. Show off your profile picture here and let the world know you’re part of the magic:

Join us and let’s celebrate fandoms together!

About

FandomFusion: A MERN platform to create, share, and explore lists of favorite anime, games, and movies with fellow fans. 🌟

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 94.2%
  • HTML 5.0%
  • CSS 0.8%