Skip to content

A React-based web app that allows users to search, explore, and view detailed information about Pokémon using the PokéAPI, complete with shiny sprites, evolutions, and navigation features.

Notifications You must be signed in to change notification settings

RuiArmada/Pokedex

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

7 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Pokémon Search App

This is a React-based web application that allows users to search for and explore information about different Pokémon using data from the PokéAPI. Users can view details, explore evolutions, toggle between shiny and regular sprites, and browse through a set of pre-loaded Pokémon.

Features

  • Initial Pokémon Load: The app fetches and loads the first 50 Pokémon on startup, ensuring users have instant access to them without the need for manual search.
  • Pokémon Search: Enter a Pokémon name or ID to retrieve detailed information.
  • Pokémon Suggestions: As you type a Pokémon name, suggestions are provided based on the current input.
  • Pokémon Details: View details such as type, height, weight, and sprite images (including shiny versions).
  • Random Pokémon: Click the "Random Pokémon" button to discover a random Pokémon.
  • Evolutions: Explore the evolution chain of each Pokémon.
  • Shiny Toggle: Click on the Pokémon sprite to toggle between its normal and shiny versions.
  • Previous and Next Navigation: Browse through Pokémon using the "Previous" and "Next" buttons, with looping behavior when navigating beyond the first or last Pokémon.
  • Loading Screen: A custom loading screen with a Pokéball animation displays while data is being fetched.

Installation

Prerequisites

  • Node.js: Make sure you have Node.js installed.
  • npm or yarn: Package manager for installing dependencies.

Setup

  1. Clone the Repository

    git clone <repository-url>
    cd Pokedex
  2. Install Dependencies Run the following command to install the required dependencies:

    npm install

    or, if you prefer yarn:

    yarn install
  3. Start the Development Server Run the following command to start the app in development mode:

    npm start

    or, if using yarn:

    yarn start

    The application should open in your default browser at http://localhost:3000.

Implementation Details

Technologies Used

  • React: A JavaScript library for building user interfaces.
  • PokéAPI: This app uses PokéAPI to get all the Pokémon data.
  • CSS: Custom CSS is used for styling, including dark mode support and gradient effects based on Pokémon type.

Components

  • App: The main component that manages the Pokémon search, initial Pokémon loading, and displays navigation buttons.
  • PokemonSearch: A form that allows users to search for a Pokémon by name or ID, with live suggestions.
  • PokemonDisplay: Displays detailed information about the Pokémon, including a clickable sprite for toggling between shiny and regular versions, and a list of evolution options.
  • LoadingScreen: Displays a custom loading screen with an animated Pokéball while data is being fetched.

Key Features Explained

  • Initial Load: On startup, the first 50 Pokémon are fetched and pre-loaded into the app, ensuring a seamless user experience from the beginning.
  • Search Functionality and Suggestions: As users type a Pokémon name, suggestions are provided based on the input. The app fetches data from PokéAPI based on the selected Pokémon name or ID.
  • Shiny Toggle: Clicking on the displayed Pokémon sprite toggles between its normal and shiny versions.
  • Caching: Pokémon data is cached in localStorage to minimize API requests and improve performance.
  • Responsive Design: The app includes responsive CSS, providing an optimized experience for both desktop and mobile devices.
  • Looping Navigation: When browsing with the "Previous" and "Next" buttons, users can seamlessly loop from the first to the last Pokémon and vice versa.

CSS Styling

  • The app uses a dark theme (#0d1117 background) and custom gradients for different Pokémon types.
  • The navigation and search buttons have hover effects for better user experience.
  • Pokémon evolutions are displayed as clickable cards with gradients matching the primary Pokémon type.
  • A fancy loading screen with a bouncing Pokéball animation appears while fetching data.

Folder Structure

  • src/: Contains all source files for the project.
    • App.js: Main application logic.
    • PokemonSearch.js: Search form component with suggestions.
    • PokemonDisplay.js: Displays Pokémon details.
    • LoadingScreen.js: Displays loading animation during data fetching.
    • assets/: Contains static assets like icons.
    • App.css, PokemonDisplay.css, PokemonSearch.css, LoadingScreen.css: CSS files for component-specific styles.

Future Improvements

  • Advanced Search: Add filters to search Pokémon by type, abilities, or generation.
  • Battle Simulator: Implement a simple battle simulator between two selected Pokémon.
  • Pokémon Stats: Display base stats like HP, Attack, and Defense for each Pokémon.

About

A React-based web app that allows users to search, explore, and view detailed information about Pokémon using the PokéAPI, complete with shiny sprites, evolutions, and navigation features.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published