Skip to content

Clue355/countries_api_project

Repository files navigation

Frontend Mentor - REST Countries API

This is a solution to the REST Countries API with color theme switcher challenge on Frontend Mentor. Frontend Mentor challenges help you improve your coding skills by building realistic projects.

Table of contents

Overview

The challenge

Users should be able to:

  • See all countries from the API on the homepage
  • Search for a country using an input field
  • Filter countries by region
  • Click on a country to see more detailed information on a separate page
  • Click through to the border countries on the detail page
  • Toggle the color scheme between light and dark mode (optional)

Screenshot

Links

My process

Built with

  • Next.js - React framework
  • Tailwind - For styles
  • PnPm - disk space efficient package manager
  • Cypress - easily create tests for your modern web applications
  • Github Actions - GitHub Actions makes it easy to automate all your software workflows

What I learned

  • How to implement tests on the front-end using Cypress
    • Cypress end to end testing basics
    • Cypress testing syntax
describe("My First Test", () => {
    beforeEach(() => { cy.visit("http://localhost:3000/"); });

    it("put's the lotion on it's skin or it gets the hose again", ()
    => { cy.put("the lotion on it's skin"); });
})
  • How to check and convert a non ASCII character to an ASCII character
const normalizeString = (str) => {
    return /[^\u0000-\u007F]+/.test(str)
        ? str
                .normalize("NFD")
                .replace(/[\u0300-\u036f]/g, "")
                .toLowerCase()
        : str.toLowerCase();
};
  • How to setup a Github Actions yml file
name: Next.js CI/CD

on:
    pull_request:
        branches: [main]

jobs:
    build-and-test:
        runs-on: ubuntu-latest

        steps:
            - name: Checkout repository
              uses: actions/[email protected]

            - name: Set up Node.js
              uses: actions/[email protected]
              with:
                  node-version: "20.9.0"

            - name: Install pnpm
              run: npm install -g pnpm

Continued development

What I want to continue learning:

  • Adding different tests to my project
  • more about CI/CD tools

Useful resources

Author

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published