Skip to content

Latest commit

 

History

History
73 lines (49 loc) · 3.02 KB

README.md

File metadata and controls

73 lines (49 loc) · 3.02 KB

Gary's Pokedex

Introduction

Gary's Pokedex is a web application that allows users to explore, update, and reset Pokemon data. The app provides a user-friendly interface for viewing and interacting with Pokemon records. It is created with React + Vite.

Preview

preview

Frontend static version: https://garys-pokedex.vercel.app/ (The pokemon cards will not show up. However, you can create a pokemon and delete it. The image link you input will not load as it is tied to the database.)

Get Started

Ctrl + click here for this project's backend repo.

  • Download both this repo and the pokedex backend.
  • Navigate to the folder of the backend in your terminal, then cd into /src and run pm2 start server.mjs.
  • Navigate to garys-pokedex in your terminal and run npm run dev.
  • Open your web browser and visit http://localhost:5173/.

Features

  • View a list of Pokemon with details such as name, type, and stats.
  • Click on a Pokemon to view its detailed information.
  • Create new Pokemon entries with custom data. (A hidden digimon lurks in the database!)
  • Update existing Pokemon records to modify stats.
  • Delete unwanted Pokemon entries.
  • Reset the Pokedex data to its initial state by rebuilding the database.

What I Learned

  • Building a full-stack web application using React and Express.js.
  • Working with a relational database (SQLite) for data storage.
  • Implementing RESTful API endpoints for CRUD operations.
  • Handling data fetching from external sources and database operations.
  • Using process management with PM2 for automatic server restarts.

Struggles

Challenges I faced during development included:

  • Error handling for database operations and network requests.
  • Managing the automatic rebuild process and server restarts.
  • Debugging and testing the app to ensure stability.
  • Creating modals became convoluted as I tried to separate concerns.
  • Deploying a full stack project online proved to be more trouble than I expected!

Technologies Used

  • Frontend: React
  • Backend: Node.js, Express.js
  • Database: SQLite
  • Data Fetching: node-fetch
  • Process Management: PM2

Future Enhancements

In the future, I plan to:

  • Implement user authentication for personalized Pokedex management.
  • Enhance the user interface and user experience.
  • Add a sliding menu that will host the user's pokemon party.

Acknowledgements


Happy Pokemon exploring!