Untitled
unknown
plain_text
3 years ago
833 B
10
Indexable
import React, { createContext, useState, useContext } from "react";
// create a context with a default value
const ThemeContext = createContext("light");
function App() {
  const [theme, setTheme] = useState("light");
  const toggleTheme = () => {
    setTheme(theme === "light" ? "dark" : "light");
  };
  return (
    <ThemeContext.Provider value={theme}>
      <Header toggleTheme={toggleTheme} />
      <Content />
    </ThemeContext.Provider>
  );
}
function Header({ toggleTheme }) {
  const theme = useContext(ThemeContext);
  return (
    <header className={theme}>
      <h1>My App</h1>
      <button onClick={toggleTheme}>Toggle Theme</button>
    </header>
  );
}
function Content() {
  const theme = useContext(ThemeContext);
  return <p className={theme}>This is the content of my app</p>;
}
export default App;Editor is loading...