astro/packages/integrations/vercel
Fred K. Schott bd76716c88
[ci] update lockfile (#3162)
Co-authored-by: FredKSchott <FredKSchott@users.noreply.github.com>
2022-04-22 10:04:01 -04:00
..
src feat(vercel): Support trailingSlash (#3176) 2022-04-22 10:03:53 -04:00
CHANGELOG.md [ci] release (#3120) 2022-04-19 11:30:34 -04:00
package.json [ci] update lockfile (#3162) 2022-04-22 10:04:01 -04:00
README.md Update Vercel adapter readme 2022-04-21 14:31:45 -07:00
tsconfig.json Basic Filesystem API 2022-03-28 10:05:55 -03:00

@astrojs/vercel

Deploy your server-side rendered (SSR) Astro app to Vercel.

Use this integration in your Astro configuration file:

import { defineConfig } from 'astro/config';
import vercel from '@astrojs/vercel';

export default defineConfig({
	adapter: vercel()
});

When you build your project, Astro will know to use the .output folder format that Vercel expects.

astro build

That's it! You can deploy by CLI (vercel deploy) or by connecting your new repo in the Vercel Dashboard.

Requirements

Vercel's File System API must be enabled. You must enable it yourself by setting the environment variable: ENABLE_FILE_SYSTEM_API=1.

// vercel.json
{
  "build": {
    "env": {
      "ENABLE_FILE_SYSTEM_API": "1"
    }
  }
}

Learn more about setting enviroment variables in Vercel.

Limitations

A few known complex packages (example: puppeteer) do not support bundling and therefore will not work properly with this adapter. By default, Vercel doesn't include npm installed files & packages from your project's ./node_modules folder. To address this, the @astrojs/vercel adapter automatically bundles your final build output using esbuild.