Next.js
migration
byCodemod

Next/13/App Directory Boilerplate

/icons/calendar.svg

Last update

Jan 10, 2025

The first step to migrate your pages to the app directory is to provide a new file structure, respected by the App router.

This is attempted by this codemod, which reads the contents of your pages directory and creates the placeholder files.

The placeholder files define the basic layout and page structure.

The boilerplate includes the following:

  • placeholder page.tsx and layout.tsx files which define a UI unique to a route.
  • the placeholder app/layout.tsx file which replaces pages/_app.tsx and pages/_document.tsx files.
  • the placeholder error.tsx file which replaces pages/_error.tsx files.
  • the placeholder not-found.tsx file which replaces pages/404.tsx files.

If the codemod detects that a getStaticProps function is not used, it will be removed. Otherwise, it will remove the export keyword from the function definition.

Example

If you have the following directory:

pages
├── _app.tsx
├── _document.tsx
├── _error.tsx
├── 404.tsx
├── a.tsx
└── b
└── c.tsx

The codemod will generate the following corresponding directory:

app
├── page.tsx
├── layout.tsx
├── error.tsx
├── not-found.tsx
├── a
└── page.tsx
└── b
└── c
└── page.tsx

Build custom codemods

Use AI-powered codemod studio and automate undifferentiated tasks for yourself, colleagues or the community

background illustrationGet Started Now