A Next.js project bootstrapped with create-next-app
.
In order to be able to integrate the Wix Bookings solution with the template, you should first define a business in Wix.
Step 1: Create a business with Wix
For the integration to work, you must select Wix bookings and Wix Pricing Plans during the business creation onboarding:
If for any reason, you did not select either of the apps, you can also add it from the business dashboard, go to:
- Apps
- App Market
- Search for
Wix Bookings
andWix Pricing Plans
- Select
Wix Bookings
and clickAdd to site
- Select
Wix Pricing Plans
and clickAdd to site
See Wix Bookings Support article
Step 3: Quick Start with Deployment Platforms OR Consume APIs in the Template with an OAuth client ID
The following enables quick start deployment that automatically configures your project making it super easy to start with:
For more information, view Netlify docs.
To consume the APIs in the template, you will need to create an OAuth client ID. You will be able to create this ID from your dashboard:
- Go to
Settings
in the dashboard - Click
OAuth Apps
- Click
Create New
to create a new OAuth Apps - Once your app is created, copy the client id Only if you’ve chosen to consume APIs in the Template with an OAuth client ID, please continue to Step 4
Note: client ID should not be pushed to your source control
- run
cp .env.template .env.local
- Paste the client id you copied in step 3.4. into
NEXT_PUBLIC_WIX_CLIENT_ID=<Client ID>
Add the NEXT_PUBLIC_WIX_CLIENT_ID
environment variable with the client id value according to your deployment provider.
Note: You must complete the Get Started set up instructions before starting local development
Once you’ve obtained and configured the OAuth client Id, run the development server:
yarn
yarn dev
or
npm i
npm run dev
Open http://localhost:3000 with your browser to see the template home page.
You can start editing the Home page by modifying app/page.tsx
.
The page auto-updates as you edit the file.
Similarly, you can edit any other page - app/<route>/page.tsx
(as described in NextJs routes docs)
Checkout is implemented by redirecting visitors to Wix managed pages. You can customize the checkout from the Wix business manager from the eCommerce Settings within the “Settings” section.
To enable visitors' online checkout, please follow these steps.
Important Note: You will not need to use the site that it published. This is just to enable the checkout page to go live on the web.
- In your business dashboard click
Design Site
- Choose
Let Wix create a site for you
- Choose any template
- Click
Edit My Site Design
- Click
Publish
- In the "Publish" pop up you will be able to change the site’s address or connect a domain - this is the URL that will appear as your checkout redirect base URL. If you did not change the base URL in the Publish pop up, you can also do it later on (see Step 2)
Step 2: To accept payments using the Wix business solutions you will need to upgrade to a Business Premium Plan
In case you do not upgrade, the checkout will not be available to the customers
To change the redirect base URL, edit the URL name or Connect a domain from your business dashboard Edit the URL name by going to your dashboard:
- Click Site Actions (next to Edit Site)
- Click Rename Site
- Change the ending to Site Address (URL) and Save
- You can also Connect a Domain by following the instructions here
To customize the template and add more functionality, go to Wix API docs
This template is written in Next.js 13 using Next.js app directory.
To learn more about Next.js
, take a look at the following resources:
- Next.js Documentation - learn about Next.js features and API.
- Learn Next.js - an interactive Next.js tutorial.
- Next.js app directory
Additionally, this template uses the following libraries/features:
You can deploy this repo using any platform which supports Next.js
Version 13 (And app directory roadmap)
The repository only requires a single environment variable to be defined NEXT_PUBLIC_WIX_CLIENT_ID
which points to the client Id
required to access the business assets in Wix using APIs.