rsnext/packages/next
Jiachi Liu 6635cc07a4
Apply react-server conditions to middleware (#65424)
### What

Reland #57448 , add react-server condition resolving and apply
server-only rules to middleware

Closes NEXT-1653
Closes NEXT-3333

### Why

Middleware as the pre-routing layer that is indended to be light-weight.
Since it's on edge runtime and only run on server but not on client, it
doesn't need to include the client react bundles. Hence we apply
`react-server` export condition, that if users import React we can only
bundle server required APIs and if users use React client hooks we can
error.
2024-05-12 14:26:37 +02:00
..
compat
experimental/testmode
font
image-types
legacy
navigation-types/compat chore: update prettier to 3.2.5 (#65092) 2024-05-08 21:47:14 +02:00
src Apply react-server conditions to middleware (#65424) 2024-05-12 14:26:37 +02:00
types Support React 19 in App and Pages router (#65058) 2024-05-07 18:18:32 +02:00
amp.d.ts
amp.js
app.d.ts
app.js
babel.d.ts
babel.js
cache.d.ts Dynamic APIs (#60645) 2024-01-23 16:06:12 -08:00
cache.js Dynamic APIs (#60645) 2024-01-23 16:06:12 -08:00
client.d.ts
client.js
config.d.ts
config.js
constants.d.ts
constants.js
document.d.ts
document.js
dynamic.d.ts
dynamic.js
error.d.ts
error.js
head.d.ts
head.js
headers.d.ts
headers.js
image.d.ts
image.js
index.d.ts Bump styled-jsx to 5.1.3 (#65485) 2024-05-08 16:14:34 +00:00
jest.d.ts
jest.js
license.md
link.d.ts
link.js
navigation.d.ts
navigation.js
og.d.ts
og.js
package.json v14.3.0-canary.58 2024-05-11 23:21:54 +00:00
README.md Fix duplicate line in README (#61691) 2024-02-06 20:45:14 +00:00
router.d.ts
router.js
script.d.ts
script.js
server.d.ts feat(ts): expose MiddlewareConfig interface (#61576) 2024-02-05 11:15:58 -08:00
server.js Fix next/server api alias for ESM pkg (#61721) 2024-02-06 16:59:24 +00:00
taskfile-ncc.js Disable ncc cache instead of cache cleaning (#64804) 2024-04-20 15:45:35 +02:00
taskfile-swc.js Enable loading source maps for Next Server and React (#64527) 2024-04-22 12:40:23 +00:00
taskfile-watch.js
taskfile-webpack.js avoid output of webpack stats (#61023) 2024-01-23 11:53:19 +01:00
taskfile.js chore: update prettier to 3.2.5 (#65092) 2024-05-08 21:47:14 +02:00
tsconfig.json
types.d.ts Upgrade typescript to 5.3 (#64043) 2024-04-17 18:35:29 +02:00
types.js Upgrade typescript to 5.3 (#64043) 2024-04-17 18:35:29 +02:00
web-vitals.d.ts
web-vitals.js
webpack.config.js Support React 19 in App and Pages router (#65058) 2024-05-07 18:18:32 +02:00

Next.js

Getting Started

Used by some of the world's largest companies, Next.js enables you to create full-stack web applications by extending the latest React features, and integrating powerful Rust-based JavaScript tooling for the fastest builds.

Documentation

Visit https://nextjs.org/docs to view the full documentation.

Community

The Next.js community can be found on GitHub Discussions where you can ask questions, voice ideas, and share your projects with other people.

To chat with other community members you can join the Next.js Discord server.

Do note that our Code of Conduct applies to all Next.js community channels. Users are highly encouraged to read and adhere to them to avoid repercussions.

Contributing

Contributions to Next.js are welcome and highly appreciated. However, before you jump right into it, we would like you to review our Contribution Guidelines to make sure you have a smooth experience contributing to Next.js.

Good First Issues:

We have a list of good first issues that contain bugs that have a relatively limited scope. This is a great place for newcomers and beginners alike to get started, gain experience, and get familiar with our contribution process.

Authors

A list of the original co-authors of Next.js that helped bring this amazing framework to life!


Security

If you believe you have found a security vulnerability in Next.js, we encourage you to responsibly disclose this and NOT open a public issue. We will investigate all legitimate reports. Email security@vercel.com to disclose any security vulnerabilities. Alternatively, you can visit this link to know more about Vercel's security and report any security vulnerabilities.