From aa0c547cd6b2cc63b53ba3fc57ec009af1353ecb Mon Sep 17 00:00:00 2001
From: Aki Matsumoto <45055030+nonoakij@users.noreply.github.com>
Date: Wed, 22 Nov 2023 08:27:35 +0900
Subject: [PATCH 001/209] Fix: incorrect sample code in documentation related
to Server action (#6445)
* Fix: component not returned
* Fix: missing function statement
---
.../reference/react-dom/hooks/useFormStatus.md | 2 +-
src/content/reference/react/use-server.md | 12 +++++++-----
2 files changed, 8 insertions(+), 6 deletions(-)
diff --git a/src/content/reference/react-dom/hooks/useFormStatus.md b/src/content/reference/react-dom/hooks/useFormStatus.md
index 67a06022b..02e48973e 100644
--- a/src/content/reference/react-dom/hooks/useFormStatus.md
+++ b/src/content/reference/react-dom/hooks/useFormStatus.md
@@ -38,7 +38,7 @@ function Submit() {
return
}
-export default App() {
+export default function App() {
return (
+export default function App() {
+ return (
+
+ );
}
```
From 6570e6cd79a16ac3b1a2902632eddab7e6abb9ad Mon Sep 17 00:00:00 2001
From: Sophie Alpert
Date: Thu, 23 Nov 2023 01:44:47 -0800
Subject: [PATCH 002/209] Update useSyncExternalStore.md
---
src/content/reference/react/useSyncExternalStore.md | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/src/content/reference/react/useSyncExternalStore.md b/src/content/reference/react/useSyncExternalStore.md
index cda2ec3fa..c557eb90e 100644
--- a/src/content/reference/react/useSyncExternalStore.md
+++ b/src/content/reference/react/useSyncExternalStore.md
@@ -57,7 +57,7 @@ The current snapshot of the store which you can use in your rendering logic.
* If a different `subscribe` function is passed during a re-render, React will re-subscribe to the store using the newly passed `subscribe` function. You can prevent this by declaring `subscribe` outside the component.
-* If the store is mutated during a [non-blocking transition update](/reference/react/useTransition), React will fall back to performing that update as blocking. Specifically, React will call `getSnapshot` a second time just before applying changes to the DOM. If it returns a different value than when it was called originally, React will restart the transition update from scratch, this time applying it as a blocking update, to ensure that every component on screen is reflecting the same version of the store.
+* If the store is mutated during a [non-blocking transition update](/reference/react/useTransition), React will fall back to performing that update as blocking. Specifically, for every transition update, React will call `getSnapshot` a second time just before applying changes to the DOM. If it returns a different value than when it was called originally, React will restart the update from scratch, this time applying it as a blocking update, to ensure that every component on screen is reflecting the same version of the store.
* It's not recommended to _suspend_ a render based on a store value returned by `useSyncExternalStore`. The reason is that mutations to the external store cannot be [marked as non-blocking transition updates](/reference/react/useTransition), so they will trigger the nearest [`Suspense` fallback](/reference/react/Suspense), replacing already-rendered content on screen with a loading spinner, which typically makes a poor UX.
From 943e3ce4e52be56bcd75b679448847302f557da1 Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?Xuan=20Huang=20=28=E9=BB=84=E7=8E=84=29?=
Date: Thu, 30 Nov 2023 13:13:12 +0800
Subject: [PATCH 003/209] Captailize "Strict Mode" (#6426)
Summary of changes:
There is one "TypeScript strict mode" that is kept unchanged.
Co-authored-by: xuan.huang
---
src/content/reference/react/StrictMode.md | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/src/content/reference/react/StrictMode.md b/src/content/reference/react/StrictMode.md
index b7ca2227c..e7aa45ac7 100644
--- a/src/content/reference/react/StrictMode.md
+++ b/src/content/reference/react/StrictMode.md
@@ -95,7 +95,7 @@ Strict Mode enables the following checks in development:
---
-### Enabling strict mode for a part of the app {/*enabling-strict-mode-for-a-part-of-the-app*/}
+### Enabling Strict Mode for a part of the app {/*enabling-strict-mode-for-a-part-of-the-app*/}
You can also enable Strict Mode for any part of your application:
From b1c4b4e6de827dbbe5e0f759f00b5f8edb7b800c Mon Sep 17 00:00:00 2001
From: Xiao Chuan
Date: Wed, 6 Dec 2023 00:34:18 +0800
Subject: [PATCH 004/209] useId add server rendering usage and server api add
options (#6457)
Co-authored-by: Sebastian Silbermann
---
.../react-dom/server/renderToNodeStream.md | 3 ++
.../react-dom/server/renderToStaticMarkup.md | 2 +
.../server/renderToStaticNodeStream.md | 3 ++
.../react-dom/server/renderToString.md | 3 ++
src/content/reference/react/useId.md | 37 +++++++++++++++++++
5 files changed, 48 insertions(+)
diff --git a/src/content/reference/react-dom/server/renderToNodeStream.md b/src/content/reference/react-dom/server/renderToNodeStream.md
index a4ab2e570..fd2464b97 100644
--- a/src/content/reference/react-dom/server/renderToNodeStream.md
+++ b/src/content/reference/react-dom/server/renderToNodeStream.md
@@ -43,6 +43,9 @@ On the client, call [`hydrateRoot`](/reference/react-dom/client/hydrateRoot) to
* `reactNode`: A React node you want to render to HTML. For example, a JSX element like ``.
+* **optional** `options`: An object for server render.
+ * **optional** `identifierPrefix`: A string prefix React uses for IDs generated by [`useId`.](/reference/react/useId) Useful to avoid conflicts when using multiple roots on the same page. Must be the same prefix as passed to [`hydrateRoot`.](/reference/react-dom/client/hydrateRoot#parameters)
+
#### Returns {/*returns*/}
A [Node.js Readable Stream](https://nodejs.org/api/stream.html#readable-streams) that outputs an HTML string.
diff --git a/src/content/reference/react-dom/server/renderToStaticMarkup.md b/src/content/reference/react-dom/server/renderToStaticMarkup.md
index 01ff17ee6..607affd99 100644
--- a/src/content/reference/react-dom/server/renderToStaticMarkup.md
+++ b/src/content/reference/react-dom/server/renderToStaticMarkup.md
@@ -35,6 +35,8 @@ It will produce non-interactive HTML output of your React components.
#### Parameters {/*parameters*/}
* `reactNode`: A React node you want to render to HTML. For example, a JSX node like ``.
+* **optional** `options`: An object for server render.
+ * **optional** `identifierPrefix`: A string prefix React uses for IDs generated by [`useId`.](/reference/react/useId) Useful to avoid conflicts when using multiple roots on the same page.
#### Returns {/*returns*/}
diff --git a/src/content/reference/react-dom/server/renderToStaticNodeStream.md b/src/content/reference/react-dom/server/renderToStaticNodeStream.md
index ec3d58937..47ef74c3c 100644
--- a/src/content/reference/react-dom/server/renderToStaticNodeStream.md
+++ b/src/content/reference/react-dom/server/renderToStaticNodeStream.md
@@ -37,6 +37,9 @@ The stream will produce non-interactive HTML output of your React components.
* `reactNode`: A React node you want to render to HTML. For example, a JSX element like ``.
+* **optional** `options`: An object for server render.
+ * **optional** `identifierPrefix`: A string prefix React uses for IDs generated by [`useId`.](/reference/react/useId) Useful to avoid conflicts when using multiple roots on the same page.
+
#### Returns {/*returns*/}
A [Node.js Readable Stream](https://nodejs.org/api/stream.html#readable-streams) that outputs an HTML string. The resulting HTML can't be hydrated on the client.
diff --git a/src/content/reference/react-dom/server/renderToString.md b/src/content/reference/react-dom/server/renderToString.md
index 41bc6a982..e12692943 100644
--- a/src/content/reference/react-dom/server/renderToString.md
+++ b/src/content/reference/react-dom/server/renderToString.md
@@ -42,6 +42,9 @@ On the client, call [`hydrateRoot`](/reference/react-dom/client/hydrateRoot) to
* `reactNode`: A React node you want to render to HTML. For example, a JSX node like ``.
+* **optional** `options`: An object for server render.
+ * **optional** `identifierPrefix`: A string prefix React uses for IDs generated by [`useId`.](/reference/react/useId) Useful to avoid conflicts when using multiple roots on the same page. Must be the same prefix as passed to [`hydrateRoot`.](/reference/react-dom/client/hydrateRoot#parameters)
+
#### Returns {/*returns*/}
An HTML string.
diff --git a/src/content/reference/react/useId.md b/src/content/reference/react/useId.md
index 96a5e25a2..99d55a6a5 100644
--- a/src/content/reference/react/useId.md
+++ b/src/content/reference/react/useId.md
@@ -302,3 +302,40 @@ input { margin: 5px; }
```
+
+### useId in server rendering {/*useid-in-server-rendering*/}
+
+Choose a unique id prefix and pass it into the server options and client options. `useId` will return the same id string on server side and client side. The following example selects `react-app1` as the id prefix.
+
+```js
+import { useId } from 'react';
+
+function App() {
+ const id = useId();
+ // ...
+
+```
+
+```js
+/**
+ * server side
+ */
+
+import ReactServer from 'react-dom/server';
+
+const { pipe } = ReactServer.renderToPipeableStream(, { identifierPrefix: 'react-app1' });
+// ...
+
+```
+
+```js
+/**
+ * client side
+ */
+
+import { hydrateRoot } from 'react-dom/client';
+
+const domNode = document.getElementById('root');
+const root = hydrateRoot(domNode, reactNode, { identifierPrefix: 'react-app1' });
+
+```
From 4226fbf3bfcd3f48c7ab21053a8f4720a1129251 Mon Sep 17 00:00:00 2001
From: dan
Date: Tue, 5 Dec 2023 20:17:43 +0000
Subject: [PATCH 005/209] Edits to useId doc (#6464)
---
src/content/reference/react/useId.md | 41 ++++++++++++----------------
1 file changed, 17 insertions(+), 24 deletions(-)
diff --git a/src/content/reference/react/useId.md b/src/content/reference/react/useId.md
index 99d55a6a5..81cb3a30f 100644
--- a/src/content/reference/react/useId.md
+++ b/src/content/reference/react/useId.md
@@ -303,39 +303,32 @@ input { margin: 5px; }
-### useId in server rendering {/*useid-in-server-rendering*/}
+---
-Choose a unique id prefix and pass it into the server options and client options. `useId` will return the same id string on server side and client side. The following example selects `react-app1` as the id prefix.
+### Using the same ID prefix on the client and the server {/*using-the-same-id-prefix-on-the-client-and-the-server*/}
-```js
-import { useId } from 'react';
-
-function App() {
- const id = useId();
- // ...
-
-```
+If you [render multiple independent React apps on the same page](#specifying-a-shared-prefix-for-all-generated-ids), and some of these apps are server-rendered, make sure that the `identifierPrefix` you pass to the [`hydrateRoot`](/reference/react-dom/client/hydrateRoot) call on the client side is the same as the `identifierPrefix` you pass to the [server APIs](https://react.dev/reference/react-dom/server) such as [`renderToPipeableStream`.](/reference/react-dom/server/renderToPipeableStream)
```js
-/**
- * server side
- */
-
-import ReactServer from 'react-dom/server';
-
-const { pipe } = ReactServer.renderToPipeableStream(, { identifierPrefix: 'react-app1' });
-// ...
+// Server
+import { renderToPipeableStream } from 'react-dom/server';
+const { pipe } = renderToPipeableStream(
+ ,
+ { identifierPrefix: 'react-app1' }
+);
```
```js
-/**
- * client side
- */
-
+// Client
import { hydrateRoot } from 'react-dom/client';
const domNode = document.getElementById('root');
-const root = hydrateRoot(domNode, reactNode, { identifierPrefix: 'react-app1' });
-
+const root = hydrateRoot(
+ domNode,
+ reactNode,
+ { identifierPrefix: 'react-app1' }
+);
```
+
+You do not need to pass `identifierPrefix` if you only have one React app on the page.
From b9bf6664626a0f0f227db2ba7874018fd183644f Mon Sep 17 00:00:00 2001
From: dan
Date: Tue, 5 Dec 2023 20:19:06 +0000
Subject: [PATCH 006/209] Oops
---
src/content/reference/react/useId.md | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/src/content/reference/react/useId.md b/src/content/reference/react/useId.md
index 81cb3a30f..6d3c01674 100644
--- a/src/content/reference/react/useId.md
+++ b/src/content/reference/react/useId.md
@@ -307,7 +307,7 @@ input { margin: 5px; }
### Using the same ID prefix on the client and the server {/*using-the-same-id-prefix-on-the-client-and-the-server*/}
-If you [render multiple independent React apps on the same page](#specifying-a-shared-prefix-for-all-generated-ids), and some of these apps are server-rendered, make sure that the `identifierPrefix` you pass to the [`hydrateRoot`](/reference/react-dom/client/hydrateRoot) call on the client side is the same as the `identifierPrefix` you pass to the [server APIs](https://react.dev/reference/react-dom/server) such as [`renderToPipeableStream`.](/reference/react-dom/server/renderToPipeableStream)
+If you [render multiple independent React apps on the same page](#specifying-a-shared-prefix-for-all-generated-ids), and some of these apps are server-rendered, make sure that the `identifierPrefix` you pass to the [`hydrateRoot`](/reference/react-dom/client/hydrateRoot) call on the client side is the same as the `identifierPrefix` you pass to the [server APIs](/reference/react-dom/server) such as [`renderToPipeableStream`.](/reference/react-dom/server/renderToPipeableStream)
```js
// Server
From ae4be842dd7f464f0e45a1391845dcec5115ad91 Mon Sep 17 00:00:00 2001
From: "Bud (Mugur) Chirica"
Date: Wed, 6 Dec 2023 14:53:27 +0000
Subject: [PATCH 007/209] Fix Next JS link (#6467)
---
src/content/learn/start-a-new-react-project.md | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/src/content/learn/start-a-new-react-project.md b/src/content/learn/start-a-new-react-project.md
index 9c395d3f0..39bd40e5c 100644
--- a/src/content/learn/start-a-new-react-project.md
+++ b/src/content/learn/start-a-new-react-project.md
@@ -24,7 +24,7 @@ If you want to build a new app or a new website fully with React, we recommend p
npx create-next-app@latest
-If you're new to Next.js, check out the [Next.js tutorial.](https://nextjs.org/learn/foundations/about-nextjs)
+If you're new to Next.js, check out the [Next.js documentation.](https://nextjs.org/docs)
Next.js is maintained by [Vercel](https://vercel.com/). You can [deploy a Next.js app](https://nextjs.org/docs/app/building-your-application/deploying) to any Node.js or serverless hosting, or to your own server. Next.js also supports a [static export](https://nextjs.org/docs/pages/building-your-application/deploying/static-exports) which doesn't require a server.
From af54fc873819892f6050340df236f33a18ba5fb8 Mon Sep 17 00:00:00 2001
From: Ahmed Abdelbaset
Date: Thu, 7 Dec 2023 00:34:28 +0200
Subject: [PATCH 008/209] Link to the new Next.js tutorial instead (#6468)
---
src/content/learn/start-a-new-react-project.md | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/src/content/learn/start-a-new-react-project.md b/src/content/learn/start-a-new-react-project.md
index 39bd40e5c..a98e09669 100644
--- a/src/content/learn/start-a-new-react-project.md
+++ b/src/content/learn/start-a-new-react-project.md
@@ -24,7 +24,7 @@ If you want to build a new app or a new website fully with React, we recommend p
npx create-next-app@latest
-If you're new to Next.js, check out the [Next.js documentation.](https://nextjs.org/docs)
+If you're new to Next.js, check out the [learn Next.js course.](https://nextjs.org/learn)
Next.js is maintained by [Vercel](https://vercel.com/). You can [deploy a Next.js app](https://nextjs.org/docs/app/building-your-application/deploying) to any Node.js or serverless hosting, or to your own server. Next.js also supports a [static export](https://nextjs.org/docs/pages/building-your-application/deploying/static-exports) which doesn't require a server.
From bec75ca3487758d82a26ef8253556cdb6f3bfdc9 Mon Sep 17 00:00:00 2001
From: Sophie Alpert
Date: Tue, 12 Dec 2023 22:44:41 -0800
Subject: [PATCH 009/209] Update useSyncExternalStore.md: tweak link
this way "cannot be marked" is all the same style and you don't skim the link text and gloss over the "cannot be"
---
src/content/reference/react/useSyncExternalStore.md | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/src/content/reference/react/useSyncExternalStore.md b/src/content/reference/react/useSyncExternalStore.md
index c557eb90e..bc54d5460 100644
--- a/src/content/reference/react/useSyncExternalStore.md
+++ b/src/content/reference/react/useSyncExternalStore.md
@@ -59,7 +59,7 @@ The current snapshot of the store which you can use in your rendering logic.
* If the store is mutated during a [non-blocking transition update](/reference/react/useTransition), React will fall back to performing that update as blocking. Specifically, for every transition update, React will call `getSnapshot` a second time just before applying changes to the DOM. If it returns a different value than when it was called originally, React will restart the update from scratch, this time applying it as a blocking update, to ensure that every component on screen is reflecting the same version of the store.
-* It's not recommended to _suspend_ a render based on a store value returned by `useSyncExternalStore`. The reason is that mutations to the external store cannot be [marked as non-blocking transition updates](/reference/react/useTransition), so they will trigger the nearest [`Suspense` fallback](/reference/react/Suspense), replacing already-rendered content on screen with a loading spinner, which typically makes a poor UX.
+* It's not recommended to _suspend_ a render based on a store value returned by `useSyncExternalStore`. The reason is that mutations to the external store cannot be marked as [non-blocking transition updates](/reference/react/useTransition), so they will trigger the nearest [`Suspense` fallback](/reference/react/Suspense), replacing already-rendered content on screen with a loading spinner, which typically makes a poor UX.
For example, the following are discouraged:
From e98c3939a7c55e0ba2f0ae5beba3b7a1298b8d23 Mon Sep 17 00:00:00 2001
From: Danilo Woznica
Date: Wed, 13 Dec 2023 18:02:16 +0000
Subject: [PATCH 010/209] fix(sandpack-template): use custom react sandpack
template (#6484)
* fix(sandpack-template): use custom react sandpack template
* refactor: Remove console.log statement
Remove console.log(filePath); from createFileMap.ts
* style: Update file paths in Sandpack components
Update file paths in Sandpack components to use root folder and variables
---
.../MDX/Sandpack/DownloadButton.tsx | 7 ++-
src/components/MDX/Sandpack/SandpackRoot.tsx | 13 +++--
src/components/MDX/Sandpack/createFileMap.ts | 17 ++++--
src/components/MDX/Sandpack/index.tsx | 4 +-
src/components/MDX/Sandpack/template.ts | 54 +++++++++++++++++++
5 files changed, 81 insertions(+), 14 deletions(-)
create mode 100644 src/components/MDX/Sandpack/template.ts
diff --git a/src/components/MDX/Sandpack/DownloadButton.tsx b/src/components/MDX/Sandpack/DownloadButton.tsx
index d6b1c3299..94cf13ddc 100644
--- a/src/components/MDX/Sandpack/DownloadButton.tsx
+++ b/src/components/MDX/Sandpack/DownloadButton.tsx
@@ -5,6 +5,7 @@
import {useSyncExternalStore} from 'react';
import {useSandpack} from '@codesandbox/sandpack-react/unstyled';
import {IconDownload} from '../../Icon/IconDownload';
+import {AppJSPath, StylesCSSPath, SUPPORTED_FILES} from './createFileMap';
export interface DownloadButtonProps {}
let supportsImportMap = false;
@@ -32,8 +33,6 @@ function useSupportsImportMap() {
return useSyncExternalStore(subscribe, getCurrentValue, getServerSnapshot);
}
-const SUPPORTED_FILES = ['/App.js', '/styles.css'];
-
export function DownloadButton({
providedFiles,
}: {
@@ -49,8 +48,8 @@ export function DownloadButton({
}
const downloadHTML = () => {
- const css = sandpack.files['/styles.css']?.code ?? '';
- const code = sandpack.files['/App.js']?.code ?? '';
+ const css = sandpack.files[StylesCSSPath]?.code ?? '';
+ const code = sandpack.files[AppJSPath]?.code ?? '';
const blob = new Blob([
`
diff --git a/src/components/MDX/Sandpack/SandpackRoot.tsx b/src/components/MDX/Sandpack/SandpackRoot.tsx
index df0c757f2..d47fd903c 100644
--- a/src/components/MDX/Sandpack/SandpackRoot.tsx
+++ b/src/components/MDX/Sandpack/SandpackRoot.tsx
@@ -9,6 +9,7 @@ import {SandpackLogLevel} from '@codesandbox/sandpack-client';
import {CustomPreset} from './CustomPreset';
import {createFileMap} from './createFileMap';
import {CustomTheme} from './Themes';
+import {template} from './template';
type SandpackProps = {
children: React.ReactNode;
@@ -70,17 +71,19 @@ function SandpackRoot(props: SandpackProps) {
const codeSnippets = Children.toArray(children) as React.ReactElement[];
const files = createFileMap(codeSnippets);
- files['/styles.css'] = {
- code: [sandboxStyle, files['/styles.css']?.code ?? ''].join('\n\n'),
- hidden: !files['/styles.css']?.visible,
+ files['/src/styles.css'] = {
+ code: [sandboxStyle, files['/src/styles.css']?.code ?? ''].join('\n\n'),
+ hidden: !files['/src/styles.css']?.visible,
};
return (
{
return codeSnippets.reduce(
(result: Record, codeSnippet: React.ReactElement) => {
@@ -17,7 +27,7 @@ export const createFileMap = (codeSnippets: any) => {
if (props.meta) {
const [name, ...params] = props.meta.split(' ');
- filePath = '/' + name;
+ filePath = rootFolder + name;
if (params.includes('hidden')) {
fileHidden = true;
}
@@ -26,15 +36,16 @@ export const createFileMap = (codeSnippets: any) => {
}
} else {
if (props.className === 'language-js') {
- filePath = '/App.js';
+ filePath = AppJSPath;
} else if (props.className === 'language-css') {
- filePath = '/styles.css';
+ filePath = StylesCSSPath;
} else {
throw new Error(
`Code block is missing a filename: ${props.children}`
);
}
}
+
if (result[filePath]) {
throw new Error(
`File ${filePath} was defined multiple times. Each file snippet should have a unique path name`
diff --git a/src/components/MDX/Sandpack/index.tsx b/src/components/MDX/Sandpack/index.tsx
index 6873547a1..6755ba8de 100644
--- a/src/components/MDX/Sandpack/index.tsx
+++ b/src/components/MDX/Sandpack/index.tsx
@@ -3,7 +3,7 @@
*/
import {lazy, memo, Children, Suspense} from 'react';
-import {createFileMap} from './createFileMap';
+import {AppJSPath, createFileMap} from './createFileMap';
const SandpackRoot = lazy(() => import('./SandpackRoot'));
@@ -57,7 +57,7 @@ export default memo(function SandpackWrapper(props: any): any {
);
let activeCode;
if (!activeCodeSnippet.length) {
- activeCode = codeSnippet['/App.js'].code;
+ activeCode = codeSnippet[AppJSPath].code;
} else {
activeCode = codeSnippet[activeCodeSnippet[0]].code;
}
diff --git a/src/components/MDX/Sandpack/template.ts b/src/components/MDX/Sandpack/template.ts
new file mode 100644
index 000000000..9ead18a14
--- /dev/null
+++ b/src/components/MDX/Sandpack/template.ts
@@ -0,0 +1,54 @@
+export const template = {
+ '/src/index.js': {
+ hidden: true,
+ code: `import React, { StrictMode } from "react";
+import { createRoot } from "react-dom/client";
+import "./styles.css";
+
+import App from "./App";
+
+const root = createRoot(document.getElementById("root"));
+root.render(
+
+
+
+);`,
+ },
+ '/package.json': {
+ hidden: true,
+ code: JSON.stringify(
+ {
+ name: 'react.dev',
+ version: '0.0.0',
+ main: '/src/index.js',
+ scripts: {
+ start: 'react-scripts start',
+ build: 'react-scripts build',
+ test: 'react-scripts test --env=jsdom',
+ eject: 'react-scripts eject',
+ },
+ dependencies: {
+ react: '^18.0.0',
+ 'react-dom': '^18.0.0',
+ 'react-scripts': '^5.0.0',
+ },
+ },
+ null,
+ 2
+ ),
+ },
+ '/public/index.html': {
+ hidden: true,
+ code: `
+
+
+
+
+ Document
+
+
+
+
+`,
+ },
+};
From 01e80fd1413eecd2bfd1415294a3c929cf9211d9 Mon Sep 17 00:00:00 2001
From: Ehtesham Siddiqui
Date: Sat, 16 Dec 2023 00:07:27 +0530
Subject: [PATCH 011/209] Add React India 2024 conference (#6481)
* feat: add react india 2024
* update: move react india 2024 in date order
* update: move conferences to past section
* refactor: sort past conferences
---
src/content/community/conferences.md | 81 +++++++++++++++-------------
1 file changed, 43 insertions(+), 38 deletions(-)
diff --git a/src/content/community/conferences.md b/src/content/community/conferences.md
index 1c164a098..9f020966e 100644
--- a/src/content/community/conferences.md
+++ b/src/content/community/conferences.md
@@ -10,72 +10,77 @@ Do you know of a local React.js conference? Add it here! (Please keep the list c
## Upcoming Conferences {/*upcoming-conferences*/}
-### RedwoodJS Conference 2023 {/*redwoodjs-conference-2023*/}
-September 26 - 29, 2023. Grants Pass, Oregon + remote (hybrid event)
-
-[Website](https://www.redwoodjsconf.com/) - [Twitter](https://twitter.com/redwoodjs)
+### App.js Conf 2024 {/*appjs-conf-2024*/}
+May 22 - 24, 2024. In-person in Kraków, Poland + remote
-### React Alicante 2023 {/*react-alicante-2023*/}
-September 28 - 30, 2023. Alicante, Spain
+[Website](https://appjs.co) - [Twitter](https://twitter.com/appjsconf)
-[Website](https://reactalicante.es/) - [Twitter](https://twitter.com/reactalicante)
+### Render(ATL) 2024 🍑 {/*renderatl-2024-*/}
+June 12 - June 14, 2024. Atlanta, GA, USA
-### React Live 2023 {/*react-live-2023*/}
-September 29, 2023. Amsterdam, Netherlands
+[Website](https://renderatl.com) - [Discord](https://www.renderatl.com/discord) - [Twitter](https://twitter.com/renderATL) - [Instagram](https://www.instagram.com/renderatl/) - [Facebook](https://www.facebook.com/renderatl/) - [LinkedIn](https://www.linkedin.com/company/renderatl) - [Podcast](https://www.renderatl.com/culture-and-code#/)
-[Website](https://reactlive.nl/)
+### React India 2024 {/*react-india-2024*/}
+October 17 - 19, 2024. In-person in Goa, India (hybrid event) + Oct 15 2024 - remote day
-### React Native EU 2023 {/*react-native-eu-2023*/}
-September 7 & 8, 2023. Wrocław, Poland
+[Website](https://www.reactindia.io) - [Twitter](https://twitter.com/react_india) - [Facebook](https://www.facebook.com/ReactJSIndia) - [Youtube](https://www.youtube.com/channel/UCaFbHCBkPvVv1bWs_jwYt3w)
-[Website](https://react-native.eu) - [Twitter](https://twitter.com/react_native_eu) - [Facebook](https://www.facebook.com/reactnativeeu)
+## Past Conferences {/*past-conferences*/}
-### RenderCon Kenya 2023 {/*rendercon-kenya-2023*/}
-September 29 - 30, 2023. Nairobi, Kenya
+### React Day Berlin 2023 {/*react-day-berlin-2023*/}
+December 8 & 12, 2023. In-person in Berlin, Germany + remote first interactivity (hybrid event)
-[Website](https://rendercon.org/) - [Twitter](https://twitter.com/renderconke) - [LinkedIn](https://www.linkedin.com/company/renderconke/) - [YouTube](https://www.youtube.com/channel/UC0bCcG8gHUL4njDOpQGcMIA)
+[Website](https://reactday.berlin) - [Twitter](https://twitter.com/reactdayberlin) - [Facebook](https://www.facebook.com/reactdayberlin/) - [Videos](https://portal.gitnation.org/events/react-day-berlin-2023)
-### React India 2023 {/*react-india-2023*/}
-October 5 - 7, 2023. In-person in Goa, India (hybrid event) + Oct 3 2023 - remote day
+### React Summit US 2023 {/*react-summit-us-2023*/}
+November 13 & 15, 2023. In-person in New York, US + remote first interactivity (hybrid event)
-[Website](https://www.reactindia.io) - [Twitter](https://twitter.com/react_india) - [Facebook](https://www.facebook.com/ReactJSIndia) - [Youtube](https://www.youtube.com/channel/UCaFbHCBkPvVv1bWs_jwYt3w)
+[Website](https://reactsummit.us) - [Twitter](https://twitter.com/reactsummit) - [Facebook](https://www.facebook.com/reactamsterdam) - [Videos](https://portal.gitnation.org/events/react-summit-us-2023)
-### React Brussels 2023 {/*react-brussels-2023*/}
-October 13th 2023. In-person in Brussels, Belgium + Remote (hybrid)
+### reactjsday 2023 {/*reactjsday-2023*/}
+October 27th 2023. In-person in Verona, Italy and online (hybrid event)
-[Website](https://www.react.brussels/) - [Twitter](https://twitter.com/BrusselsReact)
+[Website](https://2023.reactjsday.it/) - [Twitter](https://twitter.com/reactjsday) - [Facebook](https://www.facebook.com/GrUSP/) - [YouTube](https://www.youtube.com/c/grusp)
### React Advanced 2023 {/*react-advanced-2023*/}
October 20 & 23, 2023. In-person in London, UK + remote first interactivity (hybrid event)
[Website](https://www.reactadvanced.com/) - [Twitter](https://twitter.com/ReactAdvanced) - [Facebook](https://www.facebook.com/ReactAdvanced) - [Videos](https://portal.gitnation.org/events/react-advanced-conference-2023)
-### reactjsday 2023 {/*reactjsday-2023*/}
-October 27th 2023. In-person in Verona, Italy and online (hybrid event)
+### React Brussels 2023 {/*react-brussels-2023*/}
+October 13th 2023. In-person in Brussels, Belgium + Remote (hybrid)
-[Website](https://2023.reactjsday.it/) - [Twitter](https://twitter.com/reactjsday) - [Facebook](https://www.facebook.com/GrUSP/) - [YouTube](https://www.youtube.com/c/grusp)
+[Website](https://www.react.brussels/) - [Twitter](https://twitter.com/BrusselsReact)
-### React Summit US 2023 {/*react-summit-us-2023*/}
-November 13 & 15, 2023. In-person in New York, US + remote first interactivity (hybrid event)
+### React India 2023 {/*react-india-2023*/}
+October 5 - 7, 2023. In-person in Goa, India (hybrid event) + Oct 3 2023 - remote day
-[Website](https://reactsummit.us) - [Twitter](https://twitter.com/reactsummit) - [Facebook](https://www.facebook.com/reactamsterdam) - [Videos](https://portal.gitnation.org/events/react-summit-us-2023)
+[Website](https://www.reactindia.io) - [Twitter](https://x.com/react_india) - [Facebook](https://www.facebook.com/ReactJSIndia) - [Youtube](https://www.youtube.com/channel/UCaFbHCBkPvVv1bWs_jwYt3w)
-### React Day Berlin 2023 {/*react-day-berlin-2023*/}
-December 8 & 12, 2023. In-person in Berlin, Germany + remote first interactivity (hybrid event)
+### RenderCon Kenya 2023 {/*rendercon-kenya-2023*/}
+September 29 - 30, 2023. Nairobi, Kenya
-[Website](https://reactday.berlin) - [Twitter](https://twitter.com/reactdayberlin) - [Facebook](https://www.facebook.com/reactdayberlin/) - [Videos](https://portal.gitnation.org/events/react-day-berlin-2023)
+[Website](https://rendercon.org/) - [Twitter](https://twitter.com/renderconke) - [LinkedIn](https://www.linkedin.com/company/renderconke/) - [YouTube](https://www.youtube.com/channel/UC0bCcG8gHUL4njDOpQGcMIA)
-### App.js Conf 2024 {/*appjs-conf-2024*/}
-May 22 - 24, 2024. In-person in Kraków, Poland + remote
+### React Live 2023 {/*react-live-2023*/}
+September 29, 2023. Amsterdam, Netherlands
-[Website](https://appjs.co) - [Twitter](https://twitter.com/appjsconf)
+[Website](https://reactlive.nl/)
-### Render(ATL) 2024 🍑 {/*renderatl-2024-*/}
-June 12 - June 14, 2024. Atlanta, GA, USA
+### React Alicante 2023 {/*react-alicante-2023*/}
+September 28 - 30, 2023. Alicante, Spain
-[Website](https://renderatl.com) - [Discord](https://www.renderatl.com/discord) - [Twitter](https://twitter.com/renderATL) - [Instagram](https://www.instagram.com/renderatl/) - [Facebook](https://www.facebook.com/renderatl/) - [LinkedIn](https://www.linkedin.com/company/renderatl) - [Podcast](https://www.renderatl.com/culture-and-code#/)
+[Website](https://reactalicante.es/) - [Twitter](https://twitter.com/reactalicante)
-## Past Conferences {/*past-conferences*/}
+### RedwoodJS Conference 2023 {/*redwoodjs-conference-2023*/}
+September 26 - 29, 2023. Grants Pass, Oregon + remote (hybrid event)
+
+[Website](https://www.redwoodjsconf.com/) - [Twitter](https://twitter.com/redwoodjs)
+
+### React Native EU 2023 {/*react-native-eu-2023*/}
+September 7 & 8, 2023. Wrocław, Poland
+
+[Website](https://react-native.eu) - [Twitter](https://twitter.com/react_native_eu) - [Facebook](https://www.facebook.com/reactnativeeu)
### React Rally 2023 🐙 {/*react-rally-2023*/}
August 17 & 18, 2023. Salt Lake City, UT, USA
From e3c25d1a5f202bada2b0105b91e9a48935414c6c Mon Sep 17 00:00:00 2001
From: Ehtesham Siddiqui
Date: Sat, 16 Dec 2023 00:18:30 +0530
Subject: [PATCH 012/209] data: add react mumbai meetup (#6396)
---
src/content/community/meetups.md | 1 +
1 file changed, 1 insertion(+)
diff --git a/src/content/community/meetups.md b/src/content/community/meetups.md
index 644bbcee3..000eeb43c 100644
--- a/src/content/community/meetups.md
+++ b/src/content/community/meetups.md
@@ -101,6 +101,7 @@ Do you have a local React.js meetup? Add it here! (Please keep the list alphabet
* [Bangalore (React Native)](https://www.meetup.com/React-Native-Bangalore-Meetup)
* [Chennai](https://www.meetup.com/React-Chennai/)
* [Delhi NCR](https://www.meetup.com/React-Delhi-NCR/)
+* [Mumbai](https://reactmumbai.dev)
* [Pune](https://www.meetup.com/ReactJS-and-Friends/)
## Indonesia {/*indonesia*/}
From bb65ace6e0b844561153e0011e20ec317dc2899d Mon Sep 17 00:00:00 2001
From: geeseyj
Date: Fri, 15 Dec 2023 15:01:53 -0600
Subject: [PATCH 013/209] Fix #6487 specify which `Sandpack` files go into a
`src` directory (#6496)
* specify which sandbox files go in src directory
* fix some stragglers
---
src/components/MDX/Sandpack/createFileMap.ts | 8 +-
.../blog/2023/03/16/introducing-react-dev.md | 4 +-
.../learn/add-react-to-an-existing-project.md | 4 +-
src/content/learn/adding-interactivity.md | 2 +-
.../learn/choosing-the-state-structure.md | 62 +++++-----
src/content/learn/describing-the-ui.md | 14 +--
src/content/learn/escape-hatches.md | 20 ++--
.../extracting-state-logic-into-a-reducer.md | 106 +++++++++---------
.../importing-and-exporting-components.md | 26 ++---
.../javascript-in-jsx-with-curly-braces.md | 4 +-
src/content/learn/keeping-components-pure.md | 38 +++----
.../learn/lifecycle-of-reactive-effects.md | 44 ++++----
src/content/learn/managing-state.md | 32 +++---
.../learn/manipulating-the-dom-with-refs.md | 12 +-
.../learn/passing-data-deeply-with-context.md | 56 ++++-----
.../learn/passing-props-to-a-component.md | 38 +++----
.../learn/preserving-and-resetting-state.md | 42 +++----
.../queueing-a-series-of-state-updates.md | 8 +-
.../learn/reacting-to-input-with-state.md | 14 +--
.../learn/removing-effect-dependencies.md | 48 ++++----
src/content/learn/render-and-commit.md | 12 +-
src/content/learn/rendering-lists.md | 50 ++++-----
src/content/learn/responding-to-events.md | 8 +-
.../learn/reusing-logic-with-custom-hooks.md | 76 ++++++-------
.../scaling-up-with-reducer-and-context.md | 46 ++++----
.../learn/separating-events-from-effects.md | 22 ++--
.../learn/sharing-state-between-components.md | 4 +-
.../learn/state-a-components-memory.md | 16 +--
.../learn/synchronizing-with-effects.md | 36 +++---
src/content/learn/thinking-in-react.md | 6 +-
src/content/learn/tutorial-tic-tac-toe.md | 56 ++++-----
src/content/learn/typescript.md | 10 +-
.../learn/understanding-your-ui-as-a-tree.md | 22 ++--
src/content/learn/updating-arrays-in-state.md | 30 ++---
.../learn/updating-objects-in-state.md | 24 ++--
.../learn/you-might-not-need-an-effect.md | 22 ++--
.../reference/react-dom/client/createRoot.md | 12 +-
.../reference/react-dom/client/hydrateRoot.md | 16 +--
.../reference/react-dom/components/common.md | 8 +-
.../reference/react-dom/components/form.md | 18 +--
.../react-dom/components/textarea.md | 2 +-
.../reference/react-dom/createPortal.md | 18 +--
.../reference/react-dom/findDOMNode.md | 34 +++---
src/content/reference/react-dom/flushSync.md | 2 +-
.../reference/react-dom/hooks/useFormState.md | 12 +-
.../react-dom/hooks/useFormStatus.md | 10 +-
src/content/reference/react-dom/hydrate.md | 12 +-
src/content/reference/react-dom/render.md | 12 +-
.../react-dom/unmountComponentAtNode.md | 4 +-
src/content/reference/react/Children.md | 30 ++---
src/content/reference/react/Component.md | 18 +--
src/content/reference/react/StrictMode.md | 40 +++----
src/content/reference/react/Suspense.md | 92 +++++++--------
src/content/reference/react/cloneElement.md | 28 ++---
src/content/reference/react/createFactory.md | 10 +-
src/content/reference/react/forwardRef.md | 10 +-
src/content/reference/react/lazy.md | 6 +-
src/content/reference/react/use-client.md | 12 +-
src/content/reference/react/use.md | 12 +-
src/content/reference/react/useCallback.md | 18 +--
src/content/reference/react/useContext.md | 14 +--
src/content/reference/react/useDebugValue.md | 2 +-
.../reference/react/useDeferredValue.md | 22 ++--
src/content/reference/react/useEffect.md | 42 +++----
src/content/reference/react/useId.md | 2 +-
.../reference/react/useImperativeHandle.md | 8 +-
.../reference/react/useLayoutEffect.md | 24 ++--
src/content/reference/react/useMemo.md | 42 +++----
src/content/reference/react/useOptimistic.md | 4 +-
src/content/reference/react/useReducer.md | 20 ++--
src/content/reference/react/useState.md | 14 +--
.../reference/react/useSyncExternalStore.md | 4 +-
src/content/reference/react/useTransition.md | 74 ++++++------
73 files changed, 862 insertions(+), 868 deletions(-)
diff --git a/src/components/MDX/Sandpack/createFileMap.ts b/src/components/MDX/Sandpack/createFileMap.ts
index 4765f87ed..85c7f09bf 100644
--- a/src/components/MDX/Sandpack/createFileMap.ts
+++ b/src/components/MDX/Sandpack/createFileMap.ts
@@ -4,12 +4,6 @@
import type {SandpackFile} from '@codesandbox/sandpack-react/unstyled';
-/**
- * Ideally, we should update all markdown files and all the sandboxes
- * to use the same folder structure to include `src`. However, we can
- * do the same by prepending the root folder on this function.
- */
-const rootFolder = '/src/';
export const AppJSPath = `/src/App.js`;
export const StylesCSSPath = `/src/styles.css`;
export const SUPPORTED_FILES = [AppJSPath, StylesCSSPath];
@@ -27,7 +21,7 @@ export const createFileMap = (codeSnippets: any) => {
if (props.meta) {
const [name, ...params] = props.meta.split(' ');
- filePath = rootFolder + name;
+ filePath = '/' + name;
if (params.includes('hidden')) {
fileHidden = true;
}
diff --git a/src/content/blog/2023/03/16/introducing-react-dev.md b/src/content/blog/2023/03/16/introducing-react-dev.md
index d2e11fded..4ce209d71 100644
--- a/src/content/blog/2023/03/16/introducing-react-dev.md
+++ b/src/content/blog/2023/03/16/introducing-react-dev.md
@@ -57,7 +57,7 @@ If you like to learn by doing, we recommend checking out the [Tic-Tac-Toe Tutori
-```js App.js
+```js src/App.js
import { useState } from 'react';
function Square({ value, onSquareClick }) {
@@ -175,7 +175,7 @@ function calculateWinner(squares) {
}
```
-```css styles.css
+```css src/styles.css
* {
box-sizing: border-box;
}
diff --git a/src/content/learn/add-react-to-an-existing-project.md b/src/content/learn/add-react-to-an-existing-project.md
index 03f491211..f494b0ab1 100644
--- a/src/content/learn/add-react-to-an-existing-project.md
+++ b/src/content/learn/add-react-to-an-existing-project.md
@@ -67,7 +67,7 @@ Then add these lines of code at the top of your main JavaScript file (it might b
```
-```js index.js active
+```js src/index.js active
import { createRoot } from 'react-dom/client';
// Clear the existing HTML content
@@ -131,7 +131,7 @@ This lets you find that HTML element with [`document.getElementById`](https://de