Skip to content

stefanogali/panini-coffee

Repository files navigation

Next.js + Headless Wordpress E-Commerce Template

This is a Next.Js + Typescript + Tailwindcss + headless Wordpress free starter template. This project uses the Wordpress REST API and the WooCommerce REST API.

Hero Image

The live project can be found at https://panini-coffee.vercel.app/

A Next.js 14 and App Router ecommerce template featuring:

  • WordPress REST API
  • WooCommerce REST API
  • Next.js App Router
  • Products filtering by category
  • Optimized for SEO using Next.js's Metadata
  • React Server Components (RSCs) and Suspense
  • Custom React Hooks
  • New fetching and caching paradigms
  • Styling with Tailwind CSS

Instructions for running locally

Please fork or clone the repo

/~https://github.com/stefanogali/panini-coffee.git

then install the dependencies with

npm install

If you need to run Wordpress locally on your machine, you can use one of the different Local servers software (MAMP, XAMPP, Local etc.). After a fresh Wordpress installation, please add the panini-coffee theme in your Wordpress themes folder located inside wp-content/themes. If you prefer you can add the zip file directly from your wp dashboard, going to Appearance -> Themes -> Upload Theme, then navigate to panini-coffee. In your Wordpress dashboard go to Appereance -> Themes and activate the Panini Coffee theme. You will be then prompted to download and activate the One Click Demo Plugin. Please go ahead, after you should have a new entry under Appearance called Import Demo data. Click the Import Demo Data button, this will add the 2 required Plugins (Secure Custom fields and Woocommerce) and will populate the content for the pages. Activate the plugins if they are not automatically.

Woocommerce may ask you to set up your store, if so go ahead and once you finished go to WooCommerce -> Settings -> Advanced -> REST API and create the keys. You will create a Consumer Key and a Consumer Secret Key.

To run your Next.js app you will need to use the environment variables defined in .env.example

# Example to run in localhost with MAMP or XAMPP

SITE_URL = "http://localhost:8888/your_folder"
PROTOCOL = "http"
HOSTNAME = "localhost"
HOSTNAMEPORT = "8888"
IMAGE_PATHNAME = "/your_folder/wp-content/uploads/**"
WOOCOMMERCECONSUMERKEY = "your_woocommerce_consumer_key"
WOOCOMMERCECONSUMERSECRET = "your_woocommerce_customer_secret"

# OR example to run from custom domain with https

SITE_URL = "https://your-domain"
PROTOCOL = "https"
HOSTNAME = "your-domain"
HOSTNAMEPORT = "Your port or leave empty"
IMAGE_PATHNAME = "/wp-content/uploads/**"
WOOCOMMERCECONSUMERKEY = "your_woocommerce_consumer_key"
WOOCOMMERCECONSUMERSECRET = "your_woocommerce_customer_secret"

Once replaced rename your file to .env.development, then you can run

npm run dev

and the Next.js app should be running on your local with no errors.

You can start adding more pages and products, extending the functionality and customizing based on your needs. At this stage there is not functionality implemented for the checkout or the cart. The about page has a slider for the Testimonial, if you wish to add these go to your WordPress dashboard and you will find a Custom Post Type for the testimonials. Feel free to add the Testimonial posts.