Next.js
migration
byCodemod

Next/13/Upsert Use Client Directive

/icons/badge-info.svg

Made for

Next.js

/icons/calendar.svg

Last update

Jan 10, 2025

Since Next.js 13.4, you can mark the files that contain only client-side code with the use client directive at the top.

The codemod will look for identifiers and string literals common for files that contain client-side code, such as React hooks or event handlers. On the other hand, it will not upsert any directive should it spot elements indicating server-side code.

The codemod will not remove the existing use client directive even if it would suggest otherwise due to the code in question.

Example

Before

import { useState } from "react";
export default function Page() {
const [x, setX] = useState("");
return x;
}

After

"use client";
import { useState } from "react";
export default function Page() {
const [x, setX] = useState("");
return x;
}

Build custom codemods

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

background illustrationGet Started Now