For this weeks practice you will create a simple theme switcher where dark/light mode are managed using React useContext.
Once forked and cloned, navigate to the project's root directory and this project uses npm (Node Package Manager) to manage its dependencies.
The command below is a combination of installing dependencies, opening up the project on VS Code and it will run a development server on your terminal.
npm i && code . && npm run dev
-
Theme Management with
useContext
- The
useContext
hook in React allows you to access values from a context without prop-drilling. For this exercise, you're using it to manage a simple theme switcher (light/dark mode). - Define a context using
createContext()
. Remember to export the context. Follow the naming conventions when you create folders and files. Have a look at the boilerplate if you need guidance.
- The
-
Integrating Components
- In your main
App.jsx
, import the theme toggler. - Ensure that the
ThemeProvider
wraps your entire application so that the theme context is accessible everywhere.
- In your main
-
Testing
- Before pushing to GitHub, test your application and make sure it toggles the theme. Ensure everything works seamlessly.
-
Committing and Pushing
- Use
git add .
to stage your changes, followed bygit commit -m "Your commit message here"
to commit them. - Push your changes to the GitHub repository using
git push origin main
.
- Use
In the ThemeContext component we...
- useState to store the default theme (light) in order to change it from the default to dark and vice versa.
- useEffect for the DOM manipulation, to apply the colors from the Style.css.
- We return ThemeContext.Provider, and pass in the value of theme and toggleTheme to the children/nested components.
- We created a button to test the Toggle dark/light functionality.
In the CreateYourComponentsHere component:
- Destructuring the useThemeContext to use the value toggleTheme.
- Added the button component to render the toggleTheme context, to make it able to toggle between light and dark background.