Configuration

All configuration can be managed from the cms.tsx file. This file is created in the project root (or your src folder if it exists) during alinea init.

cms.tsx
import {createNextCMS} from 'alinea'

export const cms = createNextCMS({
  workspaces, schema, dashboard, preview
})

The alinea package exports a general purpose createCMS function as well as framework specific functions such as createNextCMS. The framework specific instances expose helper methods to help integrate the content into your framework of choice.

workspaces

Content can be bundled in separate Workspaces. Defining at least one is required.

schema

Describe the structure of your content using a collection of Types.

dashboard

All configuration to generate the dashboard UI for deployment goes here.

preview

A url which is used in the dashboard for live previews.

syncInterval

Optionally set the interval in seconds at which the frontend will poll for updates.

Good to know

Dealing with errors

Your config file is read and executed during the alinea dev and alinea build CLI commands. If anything goes wrong, you might see an error such as:

Error: Fail
    at file:///home/alineacms/alinea/node_modules/@alinea/generated/config.js?1706175675574:419:7
    at ModuleJob.run (node:internal/modules/esm/module_job:194:25)

To debug these situations Alinea compiles your config file with an included source map. To enable node to read the source map and report correct positions you can enable the Node.js --enable-source-maps flag. You can add it to the scripts in package.json:

{
  "scripts": {
    "dev": "NODE_OPTIONS=--enable-source-maps alinea dev -- next dev",
    "build": "NODE_OPTIONS=--enable-source-maps alinea build -- next build"
  }
}

If you're developing on Windows you can use cross-env to achieve the same.

The error will now point to the right file:

Error: Fail
    at <anonymous> (/home/alinea/apps/dev/cms.tsx:278:7)
    at ModuleJob.run (node:internal/modules/esm/module_job:194:25)