Breakpoints
Breakpoints are user-defined key/value pairs that describe the boundaries of screen sizes.
There’s no limit to the number of breakpoints; you can define as many as you want.
Register breakpoints To register your breakpoints, create an object with any keys:
export const breakpoints = {
xs: 0 ,
sm: 576 ,
md: 768 ,
lg: 992 ,
xl: 1200 ,
superLarge: 2000 ,
tvLike: 4000
} as const
The first breakpoint must start with 0
. This is required to simulate CSS cascading, e.g., everything below 576px (sm
breakoint)
will resolve to xs
breakpoint.
Danger
If you try to register a breakpoint that doesn’t start with 0, Unistyles will throw an error:
“You are trying to register breakpoints that don’t start from 0”
If you use TypeScript you need to override the library’s type:
import { breakpoints } from './breakpoints'
type AppBreakpoints = typeof breakpoints
declare module 'react-native-unistyles' {
export interface UnistylesBreakpoints extends AppBreakpoints {}
}
Finally, to register the breakpoints, call UnistylesRegistry
:
import { UnistylesRegistry } from 'react-native-unistyles'
import { breakpoints } from './breakpoints'
UnistylesRegistry
. addBreakpoints (breakpoints)
To learn more follow setup guide .
How to use breakpoints? Any style can change based on breakpoints. To do this, change a value
to an object
:
const stylesheet = createStyleSheet ( theme => ({
container: {
flex: 1 ,
justifyContent: 'center' ,
alignItems: 'center' ,
backgroundColor: theme.colors.background ,
backgroundColor: {
// your breakpoints
xs : theme.colors.background,
sm : theme.colors.barbie
}
},
text: {
color: theme.colors.typography
}
}))
You can even use it with nested objects like transform
or shadowOffset
:
const stylesheet = createStyleSheet ( theme => ({
container: {
flex: 1 ,
justifyContent: 'center' ,
alignItems: 'center' ,
backgroundColor: {
xs : theme.colors.background,
sm : theme.colors.barbie
},
transform: [
{
translateX: 100
},
{
scale: {
xs : 1.5 ,
xl : 0.9
}
}
]
}
}))
Breakpoints are also avilable with variants .
Built-in breakpoints landscape
and portrait
Even if you don’t use custom breakpoints, you can still utilize Unistyles’ predefined breakpoints available on mobile devices: portrait
and landscape
.
portrait
will resolve to your device’s width in portrait mode
landscape
will resolve to your device’s width in landscape mode
const stylesheet = createStyleSheet ( theme => ({
container: {
flex: 1 ,
justifyContent: 'center' ,
alignItems: 'center' ,
backgroundColor: {
landscape : theme.colors.background,
portrait : theme.colors.barbie
}
}
}))
Access the current breakpoint You can access the current breakpoint with the useStyles
hook:
const { breakpoint } = useStyles (stylesheet)
or with UnistylesRuntime
:
import { UnistylesRuntime } from 'react-native-unistyles'
// check the current breakpoint
export const CurrentBreakpoint = () => (
< Text >
Current breakpoint is { UnistylesRuntime.breakpoint }
</ Text >
)
Get registered breakpoints Access your registered breakpoints object with UnsitylesRuntime
:
import { UnistylesRuntime } from 'react-native-unistyles'
// check the registered breakpoints
export const RegisteredBreakpoints = () => (
< Text >
My registered breakpoint are { UnistylesRuntime.breakpoints }
</ Text >
)