A web application that provides information about countries worldwide using the REST Countries API. Users can search for countries, view details like population, region, and capital, and filter results based on their queries. The application features a clean UI and falls back to cached data if the API fails.
- Fetches data from REST Countries API.
- Search functionality to find countries by name or region.
- Displays detailed information for each country, including flag, population, region, and capital.
- Fallback mechanism using cached data in case of API fetch failure.
- Smooth transitions and responsive design.
├── public/
├── src/
│ ├── components/
│ │ ├── CountryCard.js
│ │ ├── CountriesList.js
│ │ └── CountriesListShimmer.js
│ ├── assets/
│ ├── App.js
│ ├── index.js
│ └── countriesData.js (fallback data)
├── .env
├── package.json
└── README.md
- Frontend: React.js
- Bundler: Parcel
- Styling: CSS Vanilla
- API: REST Countries API
- Deployment: Vercel / Netlify
- Node.js installed
- A package manager like npm or yarn
-
Clone the repository:
git clone https://github.com/your-username/countries-api-project.git
-
Navigate to the project directory:
cd countries-api-project
-
Install dependencies:
npm install
-
Create a
.env
file and add your API base URL:REACT_APP_BASE_URL=https://restcountries.com/v3.1
-
Start the development server:
npm start
-
Open the app in your browser at http://localhost:1234.
Check out the deployed project:
- Vercel: Countries Data
- Netlify: Nations Data
- Type a country name or region in the search bar.
- View country details, including flag, population, region, and capital.
- If the API fails, cached data is loaded automatically.
-
API Fetch Failure:
- Ensure the base URL in
.env
is correct. - Check if the API is reachable by visiting it directly in your browser.
- Ensure the base URL in
-
CORS Issues:
- If you face CORS, Use a proxy or configure the server to accept requests from your deployed domain.
- If API fetching fails sometimes, Do not worry I have implemented fallback.
-
Deployment Issues:
- Verify environment variables are set correctly in your deployment platform (e.g., Vercel or Netlify).
Contributions are welcome! Follow these steps to contribute:
- Fork the repository.
- Create a new branch:
git checkout -b feature/your-feature-name
- Make changes and commit them:
git commit -m "Added a new feature"
- Push to the branch:
git push origin feature/your-feature-name
- Create a pull request.
This project is licensed under the MIT License. See the LICENSE file for details.
- REST Countries API for providing the data.
- React.js for the framework.
- Inspiration from frontend-mentor projects showcasing country data.
For any queries or feedback, feel free to reach out:
- Email: [email protected]
- LinkedIn: immortalwebdev
- PortFolio: My-Portfolio
Thank you for checking out this project! 🙌
Created with 💝 by Piyush