This is an Encore + Next.js project starter. It's a great way to learn how to combine Encore's backend capabilities with a modern web framework — perfect for building a web app.
Go through the following steps to clone this starter:
git clone --depth=1 https://github.com/encoredev/nextjs-starter.git
cd nextjs-starter/backend
npm install # Install dependencies
encore app init # Create a new Encore application. Take note of the App ID
encore run # Inside the backend directory
frontend/package.json
, replace {{ENCORE_APP_ID}}
with the ID of your Encore application. You can see the app id in the encore.app
file.npm run gen # Inside the frontend directory
Run your Encore backend:
encore run # Inside the backend directory
In a different terminal window, run the Next.js frontend:
cd frontend
npm install
npm run dev
Open http://localhost:3000 in your browser to see the result.
While encore run
is running, open http://localhost:9400 to view Encore's local developer dashboard.
Here you can see the request you just made and a view a trace of the response.
Keep the contract between the backend and frontend in sync by regenerating the request client whenever you make a change to an Encore endpoint.
In the gen
npm scripts, replace next-js-test-ts-9wvi
with the ID of your Encore application.
npm run gen # Will create a new request client frontend/app/lib/client.ts
Follow these steps to deploy your backend to a staging environment in Encore's free development cloud.
backend
. We need to do this because the encore.app
file is not in the repo root.You can follow the deploy in the Cloud Dashboard. When the deploy is complete, your app will be available in the cloud.
frontend
as the root directory for the Vercel project.If you are running into CORS issues when calling your Encore API from your frontend then you may need to specify which
origins are allowed to access your API (via browsers). You do this by specifying the global_cors
key in the encore.app
file, which has the following structure:
global_cors: {
// allow_origins_without_credentials specifies the allowed origins for requests
// that don't include credentials. If nil it defaults to allowing all domains
// (equivalent to ["*"]).
"allow_origins_without_credentials": [
"<ORIGIN-GOES-HERE>"
],
// allow_origins_with_credentials specifies the allowed origins for requests
// that include credentials. If a request is made from an Origin in this list
// Encore responds with Access-Control-Allow-Origin: <Origin>.
//
// The URLs in this list may include wildcards (e.g. "https://*.example.com"
// or "https://*-myapp.example.com").
"allow_origins_with_credentials": [
"<DOMAIN-GOES-HERE>"
]
}
More information on CORS configuration can be found here: https://encore.dev/docs/develop/cors