Fastest E-commerce template built with React
, NextJS
, TypeScript
, @tanstack/react-query
and Tailwind CSS
. Its very easy to use, we used @tanstack/react-query
for data fetching . You can setup your api endpoint's very easily and your frontend team will love using it.
- node(18.17.0 or later)
- yarn(version 1.22.19)
- editor: Visual Studio Code(recommended)
Tech specification for this template is given below
For getting started with the template you have to follow the below procedure. First navigate to the chawkbazar
directory.
Within the project directory you'll find a .env.local.template
file just rename it as .env.local
.
** NOTE : ** This file contain env values
for local development but when you wanna use this template for your needs you need to replace this value with your own real API endpoint
.
Run below command for getting started with this template.
# on chawkbazar directory
$ yarn
$ yarn dev # which will running the template for development
If you want to test your production build in local environment then run the below commands.
# build for production
yarn build
#start template in production mode
yarn start
- To setup you site's basic information like [Logo,Site title,Description, Menus,etc] go to ->
src/settings/site-settings.ts
file - To customize tailwind configuration go to ->
tailwind.config.js
file . /public
: To change yourapi data, favicon, multi-language assets (images, placeholder)
etc here ./src/components
: This folder contains all the template related ui components ./src/containers
: This folder contains all the common sections related components./src/contexts
: This folder contains all necessary context for this template . Likecart, ui
etc./src/framework
: It's contain all the data fetching related codes. see below for more info./src/pages
: All the pages created here which is used by nextjs routing mechanism ./src/settings
: To setup your site basic setting likeprivacy page, terms page, faq settings page
etc./src/styles
: Overwrites some third party packages CSS files and our custom CSS in the tailwind.css file./src/utils
: This folder containshooks, routes, motion effect
etc.
We have used next-i18next(https://github.com/isaachinman/next-i18next) package for supporting multi-language.
/public/locales
: This folder contains all languages files. If you want to add more languages, please add your language specific folder.
/src/utils/get-direction.ts
: This file contains all RTL related codes. Change it according to your need.
For this template we didn't provide any actual rest api integration. We have used @tanstack/react-query
~~ hook pattern ~~ and fetched data from public json. You will need to edit those hook to integrate your actual API end point. Please go to framework/basic-rest/
folder for those hooks.
- Creating the hook.
- We have imported the
Product
type from@framework/types
=framework/basic-rest/types
(We have used typescript path aliasing for this. For more info please see ourtsconfig.json
file). Customize it according to your product type. - We have built an
axios instance
which calledhttp
. - We have put all ours endpoint at
@framework/utils/api-endpoints
file using constant value. Customize it according to your api endpoints. - We have built our
product hook
using@tanstack/react-query
.
- We have imported the
import { Product } from "@framework/types";
import http from "@framework/utils/http";
import { API_ENDPOINTS } from "@framework/utils/api-endpoints";
import { useQuery } from "@tanstack/react-query";
export const fetchProduct = async (_slug: string) => {
const { data } = await http.get(`${API_ENDPOINTS.PRODUCT}`);
return data;
};
export const useProductQuery = (slug: string) => {
return useQuery<Product, Error>({
queryKey: [API_ENDPOINTS.PRODUCT, slug],
queryFn: () => fetchProduct(slug),
});
};
For more information about @tanstack/react-query
please visit React Query.
** NOTE : ** We didn't provide all the endpoints to avoid some unnecessary boiler plate. You will need to customize or build according to your need.
- Using the hook
const { data, isLoading, error } = useProductQuery(slug as string);
If you want to host the template in vercel.com then please follow the below procedure
- Navigate to
chawkbazar
- Put your api endpoint at
vercel.json
file. - Now run below command
vercel