@dev-vortex/react-native-responsive-styles v1.0.1
react-native-responsive-styles
A React-Native utility created to allow correct size attribution to elements on your apps UI across different sized devices.
Instalation
yarn add @dev-vortex/react-native-responsive-stylesor
npm install --save @dev-vortex/react-native-responsive-stylesMotivation
When developing with react-native, we constantly need to manually adjust styles to look great on a variety of different screen sizes.
The idea was to allow a "replacement" or improvement to react styling by allowing a "chain" that will "understand" the provided styling, calculate the values and return the styles from react native style.
ResponsiveSheets
import { StyleSheet, PixelRatio } from 'react-native'
import ResponsiveStyles, { getDpPtCorrection } from '@dev-vortex/react-native-responsive-styles'
const dpPtCorrectionPlugin = getDpPtCorrection(PixelRatio.get(), PixelRatio.getFontScale())
const pluginsChain = [
    dpPtCorrectionPlugin, 
    StyleSheet.create
]
const styles = ResponsiveStyles.create({
    container: {
        height: '80@dp',
    },
    titleText: {
        fontSize: '20@pt',
    },
    descriptionText: {
        fontSize: '14@pt',
    },
}, pluginsChain)
...ResponsiveSheets will take the same stylesObject a regular StyleSheet will take. It is also possible to use annotations that will automatically apply the formulas to provide the expected result:
- <size>@dp- will convert the Density-independent Pixels to device real pixels (based on density).
- <size>@pt- will convert the points into correct font size.
Custom plugins
It is possible to create and add plugins to the chain (second argument in create)
The plugin signature is defined by the interface ConvertPluginFunction. And it should expect to receive the value of a style attribute and return the same value but with the conversion applied (or the same if nothing need to be converted).
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago