Awesome
Pinterest Clone - GraphQL, ReactJS, NodeJS, Mysql
Description:
This project was made in as a way to practice my GraphQL skills. I also used it to learn how to implement an ORM into my back-end, which in this case I used Sequelize. It replicats the famous column layout that Pinteres uses, and it exemplifies several small features present in the real website. I made a GraphQL API for my backend using Apollo Server, which allowed a wall between the clients and the API. The user can also login with their google account, and all info related to the user is saved in a ClearDB MySQL database. If the user wants to upload a pin, the image (and other details) are inserted to the database and uploaded to Cloudinary as an image storage.
Time Taken:
2 weeks
Technologies Used:
- ReactJS
- NodeJS
- ExpressJS
- GraphQL
- Apollo Server / Apollo Client
- MySQL
- Sequelize ORM
- Google OAUTH
Front End:
The front-end is hosted on Netlify. The front-end repository is: https://github.com/machadop1407/pinterest-clone-frontend
Back End
This repository is for the back-end.
Design:
Database:
3 Tables:
- Users: Stores user first and last name, email, and googleId
- Pins: Stores all pins uploaded to the platform. Information for each pin include the cloudinary image id, googleId of the user that uploaded, a title, a description, and an optional url.
- SavedPins: Stores all pins that were saved by a user. Each saved pin stores the cloudinar image id and the googleId of the user saving the pin.
Server-Side:
Apollo Server:
- Express server with a graphql enpoint:
- Mutations and queries are sent to the front end and handled with Apollo-Client.
- Sequelize ORM is used for database requests
Front-End:
Front End fully developed in ReactJS using the create-react-app boiler plate