Skip to content

Commit

Permalink
Merge branch 'canary' into better-get-port
Browse files Browse the repository at this point in the history
  • Loading branch information
kodiakhq[bot] authored Sep 11, 2023
2 parents 3ae594f + ddc26c9 commit 2fef0c0
Show file tree
Hide file tree
Showing 127 changed files with 1,238 additions and 1,484 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -80,7 +80,7 @@ Dynamic rendering is useful when a route has data that is personalized to the us
>
> In most websites, routes are not fully static or fully dynamic - it's a spectrum. For example, you can have e-commerce page that uses cached product data that's revalidated at an interval, but also has uncached, personalized customer data.
>
> In Next.js, you can have dynamically rendered routes that have both cached and uncached data. This is because the RSC Payload and data are cached separetely. This allows you to opt into dynamic rendering without worrying about the performance impact of fetching all the data at request time.
> In Next.js, you can have dynamically rendered routes that have both cached and uncached data. This is because the RSC Payload and data are cached separately. This allows you to opt into dynamic rendering without worrying about the performance impact of fetching all the data at request time.
>
> Learn more about the [full-route cache](/docs/app/building-your-application/caching#full-route-cache) and [Data Cache](/docs/app/building-your-application/caching#data-cache).
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -177,19 +177,21 @@ For [`getStaticProps`](/docs/pages/api-reference/functions/get-static-props), [`
```tsx filename="pages/blog/[slug].tsx"
import { GetStaticProps, GetStaticPaths, GetServerSideProps } from 'next'

export const getStaticProps: GetStaticProps = async (context) => {
export const getStaticProps = (async (context) => {
// ...
}
}) satisfies GetStaticProps

export const getStaticPaths: GetStaticPaths = async () => {
export const getStaticPaths = (async () => {
// ...
}
}) satisfies GetStaticPaths

export const getServerSideProps: GetServerSideProps = async (context) => {
export const getServerSideProps = (async (context) => {
// ...
}
}) satisfies GetServerSideProps
```

> **Good to know:** `satisfies` was added to TypeScript in [4.9](https://www.typescriptlang.org/docs/handbook/release-notes/typescript-4-9.html). We recommend upgrading to the latest version of TypeScript.
## API Routes

The following is an example of how to use the built-in types for API routes:
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -16,33 +16,33 @@ There are several reasons why you might want to switch from Vite to Next.js:
happens due to a couple of reasons:
1. The browser needs to wait for the React code and your entire application bundle to download
and run before your code is able to send requests to load some data.
1. Your application code grows with every new feature and extra dependency you add.
1. **No automatic code splitting**: The previous issue of slow loading times can be somewhat managed with code splitting.
2. Your application code grows with every new feature and extra dependency you add.
2. **No automatic code splitting**: The previous issue of slow loading times can be somewhat managed with code splitting.
However, if you try to do code splitting manually, you'll often make performance worse. It's easy
to inadvertently introduce network waterfalls when code-splitting manually. Next.js provides
automatic code splitting built into its router.
1. **Network waterfalls**: A common cause of poor performance occurs when applications make
3. **Network waterfalls**: A common cause of poor performance occurs when applications make
sequential client-server requests to fetch data. One common pattern for data fetching in an SPA
is to initially render a placeholder, and then fetch data after the component has mounted.
Unfortunately, this means that a child component that fetches data can't start fetching until
the parent component has finished loading its own data. On Next.js,
[this issue is resolved](https://github.com/reactjs/rfcs/blob/main/text/0188-server-components.md#no-client-server-waterfalls)
by fetching data in Server Components.
1. **Fast and intentional loading states**: Thanks to built-in support for
4. **Fast and intentional loading states**: Thanks to built-in support for
[Streaming with Suspense](/docs/app/building-your-application/routing/loading-ui-and-streaming#streaming-with-suspense),
with Next.js, you can be more intentional about which parts of your UI you want to load first and
in what order without introducing network waterfalls. This enables you to build pages that are
faster to load and also eliminate [layout shifts](https://web.dev/cls/).
1. **Choose the data fetching strategy**: Depending on your needs, Next.js allows you to choose your
5. **Choose the data fetching strategy**: Depending on your needs, Next.js allows you to choose your
data fetching strategy on a page and component basis. You can decide to fetch at build time, at
request time on the server, or on the client. For example, you can fetch data from your CMS and
render your blog posts at build time, which can then be efficiently cached on a CDN.
1. **Middleware**: [Next.js Middleware](/docs/app/building-your-application/routing/middleware)
6. **Middleware**: [Next.js Middleware](/docs/app/building-your-application/routing/middleware)
allows you to run code on the server before a request is completed. This is especially useful to
avoid having a flash of unauthenticated content when the user visits an authenticated-only page
by redirecting the user to a login page. The middleware is also useful for experimentation and
internationalization.
1. **Built-in Optimizations**: Images, fonts, and third-party scripts often have significant impact
7. **Built-in Optimizations**: Images, fonts, and third-party scripts often have significant impact
on an application's performance. Next.js comes with built-in components that automatically
optimize those for you.

Expand Down
2 changes: 1 addition & 1 deletion docs/02-app/02-api-reference/04-functions/cookies.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -62,7 +62,7 @@ export default function Page() {

A method that takes a cookie name, value, and options and sets the outgoing request cookie.

> **Good to know**: `.set()` is only available in a [Server Action](/docs/app/building-your-application/data-fetching/forms-and-mutations) or [Route Handler](/docs/app/building-your-application/routing/route-handlers).
> **Good to know**: HTTP does not allow setting cookies after streaming starts, so you must use `.set()` in a [Server Action](/docs/app/building-your-application/data-fetching/forms-and-mutations) or [Route Handler](/docs/app/building-your-application/routing/route-handlers).
```js filename="app/actions.js"
'use server'
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -13,13 +13,13 @@ type Repo = {
stargazers_count: number
}

export const getStaticProps: GetStaticProps<{
repo: Repo
}> = async () => {
export const getStaticProps = (async (context) => {
const res = await fetch('https://api.github.com/repos/vercel/next.js')
const repo = await res.json()
return { props: { repo } }
}
}) satisfies GetStaticProps<{
repo: Repo
}>

export default function Page({
repo,
Expand All @@ -29,7 +29,7 @@ export default function Page({
```

```jsx filename="pages/index.js" switcher
export const getStaticProps = async () => {
export async function getStaticProps() {
const res = await fetch('https://api.github.com/repos/vercel/next.js')
const repo = await res.json()
return { props: { repo } }
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ type Repo = {
stargazers_count: number
}

export const getStaticPaths: GetStaticPaths = async () => {
export const getStaticPaths = (async () => {
return {
paths: [
{
Expand All @@ -30,15 +30,15 @@ export const getStaticPaths: GetStaticPaths = async () => {
],
fallback: true, // false or "blocking"
}
}
}) satisfies GetStaticPaths

export const getStaticProps: GetStaticProps<{
repo: Repo
}> = async () => {
export const getStaticProps = (async (context) => {
const res = await fetch('https://api.github.com/repos/vercel/next.js')
const repo = await res.json()
return { props: { repo } }
}
}) satisfies GetStaticProps<{
repo: Repo
}>

export default function Page({
repo,
Expand All @@ -48,7 +48,7 @@ export default function Page({
```

```jsx filename="pages/repo/[name].js" switcher
export const getStaticPaths = async () => {
export async function getStaticPaths() {
return {
paths: [
{
Expand All @@ -61,7 +61,7 @@ export const getStaticPaths = async () => {
}
}

export const getStaticProps = async () => {
export async function getStaticProps() {
const res = await fetch('https://api.github.com/repos/vercel/next.js')
const repo = await res.json()
return { props: { repo } }
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -13,13 +13,13 @@ type Repo = {
stargazers_count: number
}

export const getServerSideProps: GetServerSideProps<{
repo: Repo
}> = async () => {
export const getServerSideProps = (async (context) => {
const res = await fetch('https://api.github.com/repos/vercel/next.js')
const repo = await res.json()
return { props: { repo } }
}
}) satisfies GetServerSideProps<{
repo: Repo
}>

export default function Page({
repo,
Expand All @@ -29,7 +29,7 @@ export default function Page({
```

```jsx filename="pages/index.js" switcher
export const getServerSideProps = async () => {
export async function getServerSideProps() {
const res = await fetch('https://api.github.com/repos/vercel/next.js')
const repo = await res.json()
return { props: { repo } }
Expand Down Expand Up @@ -99,10 +99,6 @@ This approach works well for user dashboard pages, for example. Because a dashbo
The following example shows how to fetch data at request time and pre-render the result.

```jsx
function Page({ data }) {
// Render data...
}

// This gets called on every request
export async function getServerSideProps() {
// Fetch data from external API
Expand All @@ -113,7 +109,9 @@ export async function getServerSideProps() {
return { props: { data } }
}

export default Page
export default function Page({ data }) {
// Render data...
}
```

## Caching with Server-Side Rendering (SSR)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -13,13 +13,13 @@ type Repo = {
stargazers_count: number
}

export const getServerSideProps: GetServerSideProps<{
repo: Repo
}> = async () => {
export const getServerSideProps = (async (context) => {
const res = await fetch('https://api.github.com/repos/vercel/next.js')
const repo = await res.json()
return { props: { repo } }
}
}) satisfies GetServerSideProps<{
repo: Repo
}>

export default function Page({
repo,
Expand All @@ -29,7 +29,7 @@ export default function Page({
```

```jsx filename="pages/index.js" switcher
export const getServerSideProps = async () => {
export async function getServerSideProps() {
const res = await fetch('https://api.github.com/repos/vercel/next.js')
const repo = await res.json()
return { props: { repo } }
Expand Down
16 changes: 8 additions & 8 deletions docs/03-pages/02-api-reference/02-functions/get-static-paths.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ type Repo = {
stargazers_count: number
}

export const getStaticPaths: GetStaticPaths = async () => {
export const getStaticPaths = (async () => {
return {
paths: [
{
Expand All @@ -28,15 +28,15 @@ export const getStaticPaths: GetStaticPaths = async () => {
],
fallback: true, // false or "blocking"
}
}
}) satisfies GetStaticPaths

export const getStaticProps: GetStaticProps<{
repo: Repo
}> = async () => {
export const getStaticProps = (async (context) => {
const res = await fetch('https://api.github.com/repos/vercel/next.js')
const repo = await res.json()
return { props: { repo } }
}
}) satisfies GetStaticProps<{
repo: Repo
}>

export default function Page({
repo,
Expand All @@ -46,7 +46,7 @@ export default function Page({
```

```jsx filename="pages/repo/[name].js" switcher
export const getStaticPaths = async () => {
export async function getStaticPaths() {
return {
paths: [
{
Expand All @@ -59,7 +59,7 @@ export const getStaticPaths = async () => {
}
}

export const getStaticProps = async () => {
export async function getStaticProps() {
const res = await fetch('https://api.github.com/repos/vercel/next.js')
const repo = await res.json()
return { props: { repo } }
Expand Down
10 changes: 5 additions & 5 deletions docs/03-pages/02-api-reference/02-functions/get-static-props.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -13,13 +13,13 @@ type Repo = {
stargazers_count: number
}

export const getStaticProps: GetStaticProps<{
repo: Repo
}> = async () => {
export const getStaticProps = (async (context) => {
const res = await fetch('https://api.github.com/repos/vercel/next.js')
const repo = await res.json()
return { props: { repo } }
}
}) satisfies GetStaticProps<{
repo: Repo
}>

export default function Page({
repo,
Expand All @@ -29,7 +29,7 @@ export default function Page({
```

```jsx filename="pages/index.js" switcher
export const getStaticProps = async () => {
export async function getStaticPaths() {
const res = await fetch('https://api.github.com/repos/vercel/next.js')
const repo = await res.json()
return { props: { repo } }
Expand Down
2 changes: 1 addition & 1 deletion examples/cms-builder-io/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@
"start": "next start"
},
"dependencies": {
"@builder.io/react": "^1.1.47",
"@builder.io/react": "^2.0.0",
"@builder.io/widgets": "^1.2.21",
"classnames": "2.3.1",
"date-fns": "2.28.0",
Expand Down
4 changes: 2 additions & 2 deletions examples/cms-keystonejs-embedded/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -7,8 +7,8 @@
"start": "next start"
},
"dependencies": {
"@keystone-next/fields": "^9.0.0",
"@keystone-next/keystone": "^18.0.0",
"@keystone-next/fields": "^15.0.0",
"@keystone-next/keystone": "^25.0.0",
"next": "10.2.2",
"react": "18.2.0",
"react-dom": "18.2.0"
Expand Down
2 changes: 1 addition & 1 deletion examples/cms-makeswift/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@
"start": "next start"
},
"dependencies": {
"@makeswift/runtime": "0.2.2",
"@makeswift/runtime": "0.10.13",
"next": "latest",
"react": "18.2.0",
"react-dom": "18.2.0"
Expand Down
2 changes: 1 addition & 1 deletion examples/with-recoil/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,6 @@
"next": "latest",
"react": "^18.2.0",
"react-dom": "^18.2.0",
"recoil": "0.7.6"
"recoil": "0.7.7"
}
}
2 changes: 1 addition & 1 deletion lerna.json
Original file line number Diff line number Diff line change
Expand Up @@ -16,5 +16,5 @@
"registry": "https://registry.npmjs.org/"
}
},
"version": "13.4.20-canary.21"
"version": "13.4.20-canary.24"
}
2 changes: 1 addition & 1 deletion packages/create-next-app/package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "create-next-app",
"version": "13.4.20-canary.21",
"version": "13.4.20-canary.24",
"keywords": [
"react",
"next",
Expand Down
4 changes: 2 additions & 2 deletions packages/eslint-config-next/package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "eslint-config-next",
"version": "13.4.20-canary.21",
"version": "13.4.20-canary.24",
"description": "ESLint configuration used by Next.js.",
"main": "index.js",
"license": "MIT",
Expand All @@ -10,7 +10,7 @@
},
"homepage": "https://nextjs.org/docs/app/building-your-application/configuring/eslint#eslint-config",
"dependencies": {
"@next/eslint-plugin-next": "13.4.20-canary.21",
"@next/eslint-plugin-next": "13.4.20-canary.24",
"@rushstack/eslint-patch": "^1.3.3",
"@typescript-eslint/parser": "^5.4.2 || ^6.0.0",
"eslint-import-resolver-node": "^0.3.6",
Expand Down
2 changes: 1 addition & 1 deletion packages/eslint-plugin-next/package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "@next/eslint-plugin-next",
"version": "13.4.20-canary.21",
"version": "13.4.20-canary.24",
"description": "ESLint plugin for NextJS.",
"main": "dist/index.js",
"license": "MIT",
Expand Down
2 changes: 1 addition & 1 deletion packages/font/package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "@next/font",
"version": "13.4.20-canary.21",
"version": "13.4.20-canary.24",
"repository": {
"url": "vercel/next.js",
"directory": "packages/font"
Expand Down
Loading

0 comments on commit 2fef0c0

Please sign in to comment.