Getting started

    Get started by creating a new Next.js project. The following will setup a new Next.js project in your chosen directory.

    npx create-next-app@latest

    Read the full instructions in the Next.js docs

    Install Alinea

    Navigate to the newly created project directory and install the package with your preferred package manager.

    npm install alinea

    Initialize the project

    Alinea requires a config file which can be auto-generated by running alinea init. If you prefer plain Javascript over Typescript, rename the file from cms.tsx to cms.jsx.

    npx alinea init --next

    Create handle function

    Add a handler route to handle the CMS backend and previews.

    app/api/cms/route.ts
    import {cms} from '@/cms'
    import {createHandler} from 'alinea/next'
    
    const handler = createHandler(cms)
    
    export const GET = handler
    export const POST = handler

    Update the Alinea config

    src/cms.tsx
    export const cms = createCMS({
      // ... schema, workspaces
    
      // Point to your Next.js website
      baseUrl: {
        development: 'http://localhost:3000'
      },
      handlerUrl: '/api/cms',
      dashboardFile: 'admin.html',
      
      // Enable live previews
      preview: true
    })

    Adjust Next.js config

    Alinea generates a few files at build time which should not be cached when deployed in production. If you're hosting on Vercel add @alinea/generated to experimental.serverComponentsExternalPackages in next.config.js or in next.config.mjs:

    const nextConfig = {
      // ... other options
      experimental: {
        serverComponentsExternalPackages: ['@alinea/generated']
      }
    }
    
    module.exports = nextConfig

    Access the dashboard

    Congratulations, Alinea is now ready to boot!
    Have a look around in the dashboard by running:

    npx alinea dev