blob: e02695fb6f4c5471f5a6f0bad38d5eece5bd0b05 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
|
import * as React from "react";
import { HelloComponent } from "./hello";
import { NameEditComponent } from "./nameEdit";
export const App = () => {
const [name, setName] = React.useState("defaultUserName");
const [editingName, setEditingName] = React.useState("defaultUserName");
const loadUsername = () => {
setTimeout(() => {
setName("name from async call");
setEditingName("name from async call");
}, 500);
};
React.useEffect(() => {
loadUsername();
}, []);
const setUsernameState = () => {
setName(editingName);
};
return (
<>
<HelloComponent userName={name} />
<NameEditComponent
initialUserName={name}
editingName={editingName}
onNameUpdated={setUsernameState}
onEditingNameUpdated={setEditingName}
/>
</>
);
};
|