This Project is live and deployed in here Ecommerce Mobile Web
Notes: Please use your Mobile for better UI since this website is only built for Mobile UI
This project is built using Gatsby Js (React Js Framework) for generating static site which is very fast and seo friendly. I built this using my Own Boilerplate called Gatsby Complete Boilerplate for easily getting started with Gatsby Js Framework, if you are curious about the template, feel free to check it out in here and happy for any contribution.
- The project implements Redux Saga for the State Management
- Implements Redux Persistor for persist the data inside Local Storage
- Using React Hooks
- Implements Hooks useState
- Implements Hooks useEffect
- Implements Seo with React Helmet
- Implements SSR and Generate Static Files for the Production
- I just used reusable ProductList Component for display every product inside Homepage, Wishlist, Purchased and Search Page.
- Just used reusable ProductCard Component for display the detail product inside ProductList component.
- When User click Buy button and click the Wishlist button, the product will stored inside the Global State Management (For the simplicity i only using Home reducer for handle all the data since this is a small project) and the data will persisted inside the local storage.
- Social login when clicked will go to the homepage cause since i have no app id for Google and Facebook Apps API.
- / (For the Homepage)
- /login (For the Login Page)
- /product?id=123 (For the Product detail page)
- /purchased (For displaying the product that already Purchased)
- /wishlist (For displaying the product that already Wishlisted)
- /404 (For not found page)
-
Start the Project.
For starting the project You should Clone this Repo then do the start script.
# start the React project npm run start
or if you are using Yarn
# start the React project yarn start
-
You can see the project online.
I deploy this project with Netlify for free, You can check it out this link right here Ecommerce Mobile Web Notes: if You find the blank screen, maybe You need to clear your browser storage since i used the local storage and maybe it causing conflict with your current data inside storage.
# start the React project npm run start
or if you are using Yarn
# start the React project yarn start
A quick look at the top-level files and directories you'll see in this project.
.
├── node_modules
├── src ├── components
├── containers
├── lib
├── redux
├── routes
├── services
├── .eslintrc
├── .eslintignore
├── .gitignore
├── .babelrc
├── .prettierrc
├── .prettierignore
├── gatsby-browser.js
├── gatsby-config.js
├── gatsby-node.js
├── gatsby-ssr.js
├── LICENSE
├── package-lock.json
├── package.json
└── README.md
-
/node_modules
: This directory contains all of the modules of code that your project depends on (npm packages) are automatically installed. -
/src
: This directory will contain all of the code related to what you will see on the front-end of your site (what you see in the browser) such as your site header or a page template.src
is a convention for “source code”. -
/src/components
: This directory will contain all components that will be use in this project. -
/src/containers
: This directory will contain all the pages that defined in/src/routes/index.js
. -
/src/lib
: This directory will contain all the helpers functions and constant like axios settings and etc. -
/src/redux
: This directory will contain all the redux saga things. -
/src/routes
: This directory will contain all the routes that can be used in this mobile app. -
/src/services
: This directory will contain all the api services. -
.babelrc
: This file contains the babel setting for this project. -
.eslintignore
: This file tells eslint which files it should not track for eslint setting. -
.eslintrc
: This file for eslint setting for this project. -
.prettierrc
: This is a configuration file for Prettier. Prettier is a tool to help keep the formatting of your code consistent. -
gatsby-browser.js
: This file is where Gatsby expects to find any usage of the Gatsby browser APIs (if any). These allow customization/extension of default Gatsby settings affecting the browser. -
gatsby-config.js
: This is the main configuration file for a Gatsby site. This is where you can specify information about your site (metadata) like the site title and description, which Gatsby plugins you’d like to include, etc. (Check out the config docs for more detail). -
gatsby-node.js
: This file is where Gatsby expects to find any usage of the Gatsby Node APIs (if any). These allow customization/extension of default Gatsby settings affecting pieces of the site build process. -
gatsby-ssr.js
: This file is where Gatsby expects to find any usage of the Gatsby server-side rendering APIs (if any). These allow customization of default Gatsby settings affecting server-side rendering. -
LICENSE
: Gatsby is licensed under the MIT license. -
package-lock.json
(Seepackage.json
below, first). This is an automatically generated file based on the exact versions of your npm dependencies that were installed for your project. (You won’t change this file directly). -
package.json
: A manifest file for Node.js projects, which includes things like metadata (the project’s name, author, etc). This manifest is how npm knows which packages to install for your project. -
README.md
: A text file containing useful reference information about your project.