Skip to content

leojuriolli7/g3news

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

41 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

G3News

G3News is a gaming news app. It consumes the MMO Games API through Axios.

Deployed on Vercel: https://g3news.vercel.app/

Login and Sign up are disabled on Vercel because JSON Server is not deployed there. However by cloning the project it is possible to use those functionalities.

Installation

Clone the project:

git clone git@github.com:leojuriolli7/g3news.git

Go to the project directory:

cd g3news

Install the project dependencies:

npm install

Usage

First, start JSON Server:

npm run json-server

Start the application:

npm start

Technologies used:

  • React Query to make POST requests to the database.
  • React Redux Toolkit alongside Redux Persist to store the login information of the user, as to not log them out after a refresh.
  • i18next for translation.
  • Axios.
  • Formik and Yup.
  • Styled Components.
  • React Router.
  • React Lottie to display a loading animation while the API is still fetching the data.
  • React Hot Toast to display toast error messages.
  • Animate CSS to animate components.

Pages:

  • Home: This page contains a list of the Latest News of the videogame world. When one is selected, it opens the link for the news article provided by the API.
  • Games: This page has a list of games. Each game has a title, short description, an icon displaying it's platform, the publisher and release date. When a game is clicked it opens the link for the game's page provided by the API.
  • Giveaways: This page displays a list of giveaways available to enter, complete with a progress bar. When a giveaway is clicked, it opens the link for it provided by the API.
  • Sign up: This page allows the user to create a new account that will be stored on the local database using JSON Server. The forms were created with Formik and authentication was done with Yup and regex (names mustn't have numbers, password must have 5+ digits, password confirmation, etc.)
  • Login: This page allows the user to login with the account created. When logged, a profile page will now be available and reachable through a profile icon on the right-side of the header. It allows access to the profile page and to logout.
  • Profile: This is the profile page, accessible through the profile icon on the header. It displays the profile image and name of the user.

As of right now it is not possible to store profile pictures on the JSON server, but there is a test account with a picture stored on imgur: