{"id":24532683,"url":"https://github.com/follownaim/gear-arena","last_synced_at":"2026-04-08T23:35:03.480Z","repository":{"id":271182788,"uuid":"897895625","full_name":"FollowNaim/Gear-Arena","owner":"FollowNaim","description":"GearArena 🏋️‍♂️🎯⚽ - Empowering athletes with premium sports gear. A modern e-commerce platform featuring dynamic product management, responsive design, secure authentication, and engaging animations. Built with React, TailwindCSS, Firebase, ExpressJS, and MongoDB, GearArena ensures a seamless shopping experience for sports enthusiasts worldwide.","archived":false,"fork":false,"pushed_at":"2025-01-08T07:53:21.000Z","size":4244,"stargazers_count":0,"open_issues_count":0,"forks_count":1,"subscribers_count":1,"default_branch":"main","last_synced_at":"2025-09-09T23:33:08.573Z","etag":null,"topics":["firebase","framer-motion","mongodb","nodejs","reactjs","shadcn-ui"],"latest_commit_sha":null,"homepage":"https://gear-arena.vercel.app","language":"JavaScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":null,"status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/FollowNaim.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":null,"code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null}},"created_at":"2024-12-03T12:35:11.000Z","updated_at":"2025-01-08T08:03:33.000Z","dependencies_parsed_at":"2025-03-15T21:16:35.087Z","dependency_job_id":"1fe87d9c-5127-4579-ac18-466fa021211a","html_url":"https://github.com/FollowNaim/Gear-Arena","commit_stats":null,"previous_names":["follownaim/gear-arena","ar-naim/gear-arena"],"tags_count":0,"template":false,"template_full_name":null,"purl":"pkg:github/FollowNaim/Gear-Arena","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/FollowNaim%2FGear-Arena","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/FollowNaim%2FGear-Arena/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/FollowNaim%2FGear-Arena/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/FollowNaim%2FGear-Arena/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/FollowNaim","download_url":"https://codeload.github.com/FollowNaim/Gear-Arena/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/FollowNaim%2FGear-Arena/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":31579056,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-04-08T14:31:17.711Z","status":"ssl_error","status_checked_at":"2026-04-08T14:31:17.202Z","response_time":54,"last_error":"SSL_connect returned=1 errno=0 peeraddr=140.82.121.5:443 state=error: unexpected eof while reading","robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":false,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["firebase","framer-motion","mongodb","nodejs","reactjs","shadcn-ui"],"created_at":"2025-01-22T10:18:01.735Z","updated_at":"2026-04-08T23:35:03.463Z","avatar_url":"https://github.com/FollowNaim.png","language":"JavaScript","funding_links":[],"categories":[],"sub_categories":[],"readme":"# GearArena 🏋️‍♂️🎯⚽\n\n**Empowering Athletes with the Best Sports Gear**\n\nGearArena is a modern e-commerce platform offering a wide range of high-quality sports equipment and apparel. Designed for sports enthusiasts and professionals, GearArena ensures a seamless shopping experience with a responsive interface, dynamic product management, and cutting-edge design.\n\n## 🌐 Live Site\n\nExplore the live site: [GearArena](https://gear-arena.vercel.app/)\n\n## Showcase\n\n\u003cimg src='https://i.ibb.co.com/92dshjV/01.jpg'/\u003e\n\n## 🚀 Features\n\n- **Modern Design**: Built with **ShadCN** components for an intuitive and clean UI.\n- **Responsive Across Devices**: Fully optimized for mobile, tablet, and desktop users.\n- **Secure Authentication**: Login and registration with Firebase, including Google authentication.\n- **Product Management**: Add, update, and delete sports equipment effortlessly.\n- **Dynamic Sorting**: Sort products by price (ascending/descending) for easy navigation.\n- **Dark/Light Mode**: Customize your theme preference.\n- **Interactive Animations**: Enhanced visuals using React Awesome Reveal and Lottie React.\n- **Error-Free Reloads**: No redirect issues on private routes after reloads.\n\n## 🛠️ Technologies Used\n\n- **Frontend**: React, TailwindCSS, ShadCN Components, React Router\n- **Backend**: Node.js, Express.js\n- **Database**: MongoDB (Atlas)\n- **Authentication**: Firebase Authentication\n- **Hosting**:\n  - Client: [Vercel](https://gear-arena.vercel.app//)\n  - Server: [Vercel](https://geararena-server.vercel.app/)\n\n## 📋 Pages Overview\n\n### 1. **Home Page**\n\n- **Banner/Slider**: Dynamic sliders showcasing sports gear.\n- **Our Brand Values**: Note about our brand values and why we are special.\n- **Featured Products**: Highlights six top-selling items.\n- **Why Choose Us**: Information about our speciality and why you should choose us.\n- **We're on World Wide**: Statics and detailed information about our world wide work.\n- **Theme Toggle**: Switch between dark and light modes.\n\n### 2. **All Equipment Page**\n\n- Table view of all products with essential details (name, category, price, etc.).\n- **View Details** button for in-depth product information.\n\n### 3. **Add Equipment Page (Private)**\n\n- A secure form to add new products, including fields like:\n  - **Name**, **Category**, **Price**, **Stock**, **Customization Options**, and much more.\n\n### 4. **My Equipment Page (Private)**\n\n- Displays items added by the logged-in user.\n- Includes **Update** and **Delete** functionality with a confirmation modal.\n\n### 5. **View Details Page (Private)**\n\n- Beautifully designed page showing all details of a selected product.\n\n### 6. **Update Equipment Page (Private)**\n\n- Pre-filled form for easy editing of existing product details.\n\n### 7. **Authentication Pages**\n\n- **Login**: Secure login via Email/Google.\n- **Register**: Name, Email, Photo URL, Password with awesome realtime validation.\n\n### 8. **404 Error Page**\n\n- Custom-designed page for non-existent routes.\n\n## 🔐 Environment Variables\n\nSensitive credentials like Firebase config and MongoDB keys are securely stored in `.env` files.\n\n## 🌟 Unique Highlights\n\n- Built using **ShadCN** for a professional and unique design.\n- Meaningful and relevant content—no use of \"Lorem ipsum\" text.\n- Smooth navigation with persistent login states on private routes.\n- Custom Toast/Sweet Alerts for success/error messages.\n- Hosted seamlessly using Netlify and Vercel.\n\n---\n\n## 📦 Dependencies\n\n- **@radix-ui/react-accordion**: ^1.2.2 – A Radix UI component for creating collapsible accordion sections.\n- **@radix-ui/react-avatar**: ^1.1.2 – A Radix UI component for displaying user avatars.\n- **@radix-ui/react-checkbox**: ^1.1.3 – A Radix UI component for checkboxes.\n- **@radix-ui/react-dropdown-menu**: ^2.1.4 – A Radix UI component for dropdown menus.\n- **@radix-ui/react-label**: ^2.1.0 – A Radix UI component for form labels.\n- **@radix-ui/react-select**: ^2.1.2 – A Radix UI component for select dropdowns.\n- **@radix-ui/react-slot**: ^1.1.0 – A utility for dynamic component slots.\n- **autoprefixer**: ^10.4.20 – A PostCSS plugin for adding vendor prefixes automatically.\n- **class-variance-authority**: ^0.7.1 – Utility for managing className variants in React.\n- **clsx**: ^2.1.1 – Utility for conditionally constructing className strings.\n- **firebase**: ^11.0.2 – Google Firebase JavaScript SDK for app development.\n- **framer-motion**: ^11.13.1 – A motion library for React animations.\n- **hamburger-react**: ^2.5.1 – A React component for a hamburger menu button.\n- **lottie-react**: ^2.4.0 – A React library for rendering Lottie animations.\n- **lucide-react**: ^0.464.0 – A React icon library with consistent, beautiful icons.\n- **postcss**: ^8.4.49 – A tool for transforming CSS with plugins.\n- **react**: ^18.3.1 – A JavaScript library for building user interfaces.\n- **react-awesome-reveal**: ^4.2.14 – A library for animated scrollable components.\n- **react-dom**: ^18.3.1 – React library for working with the DOM.\n- **react-helmet-async**: ^2.0.5 – A library for managing document head tags asynchronously.\n- **react-hot-toast**: ^2.4.1 – A React library for toast notifications.\n- **react-icons**: ^5.4.0 – A React icon library with a wide variety of icons.\n- **react-router-dom**: ^7.0.2 – A library for declarative routing in React applications.\n- **react-tooltip**: ^5.28.0 – A React component for tooltips.\n- **sweetalert2**: ^11.14.5 – A modern, responsive, and customizable JavaScript alert library.\n- **swiper**: ^11.1.15 – A modern slider library for web and mobile.\n- **tailwind-merge**: ^2.5.5 – Utility for merging Tailwind CSS class strings.\n- **tailwindcss**: ^3.4.17 – A utility-first CSS framework.\n- **tailwindcss-animate**: ^1.0.7 – Animation utilities for Tailwind CSS.\n\n---\n\n## 📦 Dev Dependencies\n\n- **@eslint/js**: ^9.15.0 – ESLint core JavaScript functionality.\n- **@types/react**: ^18.3.12 – TypeScript definitions for React.\n- **@types/react-dom**: ^18.3.1 – TypeScript definitions for React DOM.\n- **@vitejs/plugin-react**: ^4.3.4 – Vite plugin for React integration.\n- **eslint**: ^9.15.0 – A tool for identifying and fixing JavaScript issues.\n- **eslint-plugin-react**: ^7.37.2 – ESLint plugin for React best practices.\n- **eslint-plugin-react-hooks**: ^5.0.0 – ESLint rules for React hooks.\n- **eslint-plugin-react-refresh**: ^0.4.14 – ESLint plugin for React Fast Refresh.\n- **globals**: ^15.12.0 – Global variable definitions for ESLint.\n- **vite**: ^6.0.1 – A next-generation frontend build tool.\n\n---\n\n## 🔧 How to Run\n\n1. **Clone the repository.**\n\n```bash\n   git clone https://github.com/FollowNaim/Gear-Arena\n   cd Gear-Arena\n```\n\n2. **Install Dependencies**\n\n```bash\nnpm install\n```\n\n3. **Setup Environment Variables**\n\n- create .env.local in the root directory.\n- create a firebase project and add config here\n- firebase config will look like\n\n```bash\nVITE_Projectid\nVITE_apikey\n```\n\nlike this.\n\n4. ** Run the application**\n\n```bash\nnpm run dev\n```\n\n5. **Access the app**\n\n- Open http://localhost:5173 in your browser.\n\n---\n\n## 🛠️ Deployment\n\n- Hosted on Netlify or Vercel for a fast and reliable experience.\n- Firebase Authentication requires authorized domains to ensure secure access.\n\n---\n\n## 🤝 Contribution\n\nWe welcome contributions to improve GearArena! Here's how you can get involved:\n\n1. Fork the repository.\n2. Create a new branch (`git checkout -b feature-name`).\n3. Commit your changes (`git commit -m 'Add feature'`).\n4. Push to the branch (`git push origin feature-name`).\n5. Open a Pull Request.\n\n---\n\n**Thank you for choosing GearArena—where every athlete finds their gear! 🏅**\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Ffollownaim%2Fgear-arena","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Ffollownaim%2Fgear-arena","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Ffollownaim%2Fgear-arena/lists"}