Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ceci-aguilera/habaneras_de_lino_frontend
Habaneras de Lino is an online ecommerce. This repo contains the frontend developed using NEXT JS for producing a React js web application
https://github.com/ceci-aguilera/habaneras_de_lino_frontend
django-react-ecommerce docker ecommece ecommerce-website front-end fronted-development frontend frontend-web nextjs nextjs-ecommerce nextjs-example nextjs-storefront online-store online-store-website react react-docker reactjs website
Last synced: about 2 months ago
JSON representation
Habaneras de Lino is an online ecommerce. This repo contains the frontend developed using NEXT JS for producing a React js web application
- Host: GitHub
- URL: https://github.com/ceci-aguilera/habaneras_de_lino_frontend
- Owner: Ceci-Aguilera
- Created: 2021-10-29T17:09:35.000Z (about 3 years ago)
- Default Branch: master
- Last Pushed: 2022-10-29T02:55:13.000Z (about 2 years ago)
- Last Synced: 2023-03-04T05:42:07.188Z (almost 2 years ago)
- Topics: django-react-ecommerce, docker, ecommece, ecommerce-website, front-end, fronted-development, frontend, frontend-web, nextjs, nextjs-ecommerce, nextjs-example, nextjs-storefront, online-store, online-store-website, react, react-docker, reactjs, website
- Language: JavaScript
- Homepage: https://www.habanerasdelino.com
- Size: 46.5 MB
- Stars: 6
- Watchers: 1
- Forks: 3
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Habaneras de Lino
![alt text](./public/logos/Habaneras_de_Lino_Logo.png)![Next js version](https://img.shields.io/badge/NEXT_js-12.0.8-4c566a?logo=next.js&&longCache=truelogoColor=white&colorB=pink&style=flat-square&colorA=4c566a) ![Bootstrap version](https://img.shields.io/badge/Bootstrap-5.0.2-4c566a?logo=bootstrap&&longCache=true&logoColor=white&colorB=pink&style=flat-square&colorA=4c566a) ![Django version](https://img.shields.io/badge/Django-3.2.8-4c566a?logo=django&&longCache=truelogoColor=white&colorB=pink&style=flat-square&colorA=4c566a) ![Django-RestFramework](https://img.shields.io/badge/Django_Rest_Framework-3.12.4-red.svg?longCache=true&style=flat-square&logo=django&logoColor=white&colorA=4c566a&colorB=pink) ![Commit activity](https://img.shields.io/github/commit-activity/y/Ceci-Aguilera/habaneras_de_lino_frontend/master?&&longCache=true&logoColor=white&colorB=green&style=flat-square&colorA=4c566a) ![Last Commit](https://img.shields.io/github/last-commit/Ceci-Aguilera/habaneras_de_lino_frontend/master?&&longCache=true&logoColor=white&colorB=green&style=flat-square&colorA=4c566a)
## Table of Contents
1. [Description](#introduction)
1. [Install (Run) with Docker](#docker)
1. [Installation without Docker](#installation)
1. [Screenshots of the Frontend Next js App](#screenshots_frontend)
1. [Screenshots of the Django Backend Admin Panel](#screenshots)
## Description
__Habaneras de Lino__ is an online store to buy linen and cotton clothes that offers its customers an experience of comfort, luxury ,and modernity. The clients can filter the clothing by category, collection, and other characteristics, as well as customize the product (set color, size, sleeve cut, ...), and save them in their cart as well as apply coupons for discount.- ### Useful Notes:
- This repository contains the frontend of the store that is built using NEXT js while the backend was built using Django, and has its own repository (see [Ceci-Aguilera/habaneras_de_lino_api](https://github.com/Ceci-Aguilera/habaneras_de_lino_api)). Most of the calls to the backend are made with __axios__, and for the calls involving the client's cart, a token ([Knox Token](https://james1345.github.io/django-rest-knox/)) should always be provided except when the client has never purchased at the store (is a new client).
- The cart and language of the website are managed via Context to provide a fast and pleasant experience for the client. At the top page of the store there is a switch button to change between languages (so far Spanish and English are available) and the change is made instantaneously after pressing an option. Same applies to the cart, at any action (add, edit, or delete product actions) the change is applied just after pressing the corresponding button for the action.
- The layout and design are responsive and can adapt to different screen sizes. The screen sizes taken into account correspond to Mobile, Mini-Tablet, Tablet, and Desktop Views. For this propose, react-bootstrap was used as well as the bootstrap grid.
- The payments are managed via Paypal. See [Paypal Documentation for Devs](https://developer.paypal.com/home).1. Clone the repo:
```bash
git clone https://github.com/Ceci-Aguilera/habaneras_de_lino_frontend.git
```1. Install Docker and Docker Compose
1. Configure the environment variables: Create an .env.local file inside the root folder and set up the following environment variables:
```text
NEXT_PUBLIC_API_DOMAIN_NAME (The url of the backend, for example, https://backend_api.com/)
NEXT_PUBLIC_PAYPAL_CLIENT_ID (The paypal client id)
```
To configure Paypal and obtain the client ID follow these steps:
1. First log in into your developer account (developer.paypal > Log Into Dashboard) or create a new one (Paypal.com > Developer > Get API Credentials).
1. PayPal creates 2 default sandbox accounts (one for bussines and one for personal use), which can be used for the next step, but it is recommended to create a new one for the the Habaneras de Lino App that we shall create next. To create the new sandbox account go to SANDBOX > Accounts > Create Account > (Select Business Account).
3.Then proceed to Dashboard > My Apps & Credentials > Create App and use the previously created sandbox account (the business account). You will need to copy the Client ID and update the NEXT_PUBLIC_PAYPAL_CLIENT_ID.1. Run the command:
```bash
docker-compose up --build
```1. Congratulations =) !!! the app should be running in [localhost:3000](http://localhost:3000)
## Installation without Docker
1. Clone the repo:
```bash
git clone https://github.com/Ceci-Aguilera/habaneras_de_lino_frontend.git
```1. Install dependencies:
```bash
npm install
```1. Configure the environment variables: Create an .env.local file inside the root folder and set up the following environment variables:
```text
NEXT_PUBLIC_API_DOMAIN_NAME (The url of the backend, for example, https://backend_api.com/)
NEXT_PUBLIC_PAYPAL_CLIENT_ID (The paypal client id)
```
To configure Paypal and obtain the client ID follow these steps:
1. First log in into your developer account (developer.paypal > Log Into Dashboard) or create a new one (Paypal.com > Developer > Get API Credentials).
1. PayPal creates 2 default sandbox accounts (one for bussines and one for personal use), which can be used for the next step, but it is recommended to create a new one for the the Habaneras de Lino App that we shall create next. To create the new sandbox account go to SANDBOX > Accounts > Create Account > (Select Business Account).
3.Then proceed to Dashboard > My Apps & Credentials > Create App and use the previously created sandbox account (the business account). You will need to copy the Client ID and update the NEXT_PUBLIC_PAYPAL_CLIENT_ID.
```1. Run the app
```bash
npx next dev
```1. Congratulations =) !!! the app should be running in [localhost:3000](http://localhost:3000)
## Screenshots of the Frontend NEXT JS App
### Mobile View
![alt text](./screenshots/Product_Grid_Mobile_1.png) ![alt text](./screenshots/Product_Grid_Mobile_2.png) ![alt text](./screenshots/Product_Grid_Mobile_3.png)
![alt text](./screenshots/Product_Detail_Mobile.png) ![alt text](./screenshots/Product_Detail_Mobile_2.png) ![alt text](./screenshots/Wholesalers_Discount_Mobile.png)
![alt text](./screenshots/Shiiping_Mobile_1.png) ![alt text](./screenshots/Shiiping_Mobile_4.png) ![alt text](./screenshots/Shiiping_Mobile_3.png)
---
### Desktop View![alt text](./screenshots/Luxury_Collection_3.png)
---
![alt text](./screenshots/Pants_1.png)
---
![alt text](./screenshots/Cancun_Collection_1.png)
---
![alt text](./screenshots/Product_Detail.png)
---
![alt text](./screenshots/Cart.png)
---
![alt text](./screenshots/Shipping_Info.png)
---
![alt text](./screenshots/Shipping_Info_2.png)
---
## Screenshots of the Django Backend Admin Panel
![alt text](./screenshots/Habaneras_de_Lino_Api.png)
---
![alt text](./screenshots/Habaneras_de_Lino_Api_2.png)
---
![alt text](./screenshots/Habaneras_de_Lino_Api_3.png)