bene : studio is a global consultancy, helping startups, enterprises and HealthTech companies to have better product
Themes in React and ReactNative
data:image/s3,"s3://crabby-images/30fe4/30fe49fb8148c14b06e00d8c2d173f622e05f6e0" alt="react-themes-blog"
Pardon the interruption, we have an important message!
We are looking to expand our team with talented developers. Check out our open positions and apply.
At bene : studio we love knowledge sharing to help the community of professionals. With 10+ years and over 100 projects behind us, we have a vast amount of experience. This is why we have launched a knowledge base on our blog with regular updates of tutorials, best practices, and open source solutions.
These materials come from our internal workshops with our team of developers and engineers.
data:image/s3,"s3://crabby-images/244c8/244c8ae0fa9c48f569ca631bf2249a9b73868656" alt=""
When developing a large scale app it is a good idea to build our own UI components. The styles should be factored out to be DRY.
UPDATE: Implementation with HOOKS! 🎉
Hooks are available for a while, so use them! See the very easy implementation below:
import React, { createContext } from 'react';
import { Text, TouchableHighlight } from 'react-native';
// create the context
const ThemeContext = createContext(lightTheme);
// custom hook for theme
const useTheme = () => useContext(ThemeContext);
const Button = ({ text }) => {
const theme = useTheme();
return (
<TouchableHighlight>
<Text style={{ theme.color }}>{text}</Text>
</TouchableHighlight>
);
}
const App = () => (
<ThemeContext.Provider value={darkTheme}>
<Button text="Dummy Text" />
</ThemeContext.Provider>
);
Context
React context
is a suitable tool for dependency injection. Similar to props
but propagates implicitly. Let’s inject our theme.
<ThemeProvider theme={lightTheme}>
<Button>Tap me!</Button>
</ThemeProvider>
data:image/s3,"s3://crabby-images/b2e33/b2e3327c0675c0efe682d1174f7f2e728184ed81" alt=""
Button
1st param is props
, 2nd is context
.
contextTypes
has to be defined in order to receive properties in context
. Otherwise context
will be empty.
const Button = ({ text }, { theme }) => (
<TouchableHighlight>
<Text style={{ theme.color }}>{text}</Text>
</TouchableHighlight>
)
Button.contextTypes = {
theme: PropTypes.shape({
color: PropTypes.string
})
}
ThemeProvider
The return value of getChildContext()
will be propagated to its children down the component tree as context
.
childContextTypes
property is needed to defined.
class ThemeProvider extends React.Component {
getChildContext() {
return {
theme: this.props.theme
}
}
render() {
return this.props.children
}
}ThemeProvider.childContextTypes = {
theme: PropTypes.shape({
color: PropTypes.string
})
}
Change Themes
Themes can be changed through props
. The example below toggles two themes in the state.
data:image/s3,"s3://crabby-images/a4954/a4954a3e2147a11113ea528ab813804826e01268" alt=""
data:image/s3,"s3://crabby-images/09ce4/09ce477c65d7f9c5cedb1ea8f2e5ef36f5e2bb63" alt=""
Working Example
You can try out a working example both on iOS and Android after setting up development environment.
react-native run-ios react-native run-android
https://github.com/adambene/reactnative-themeapp
Did you like this? Join us!
Want to ask some questions? Share them with us via e-mail to partner@benestudio.co and we can set up a talk with our engineers.
Fancy working for the studio where you can work on international projects and write articles like this? Check out our open positions!
Looking for a partner for your next project? Check out our services page to see what we do and let’s set up a free consultation.
data:image/s3,"s3://crabby-images/30fe4/30fe49fb8148c14b06e00d8c2d173f622e05f6e0" alt="react-themes-blog"