Reading time: 2 minutes
When implementing a checkbox from the React Native Paper library Checkbox React Native Paper on Android, the element appears correctly, but on iOS, the checkbox box is not displayed:
iOS Display:
data:image/s3,"s3://crabby-images/18bfc/18bfc68bff4e05bb9d6efd0f1d824abd5bb19b8f" alt=""
Android Display:
data:image/s3,"s3://crabby-images/ccd10/ccd1013c7853fe0786d7b1fabdfb31106e24a5ed" alt=""
If we look at the documentation (Checkbox React Native Paper), it indicates that the boxes appear on Android, but not on iOS:
data:image/s3,"s3://crabby-images/b2f65/b2f6521a906d7894e33bd360eaadc223bd2eea03" alt=""
To fix this and make the checkbox display the same on iOS as it does on Android, you need to do the following:
Starting with this code where it displays correctly on Android:
import React from "react"; import { Checkbox } from 'react-native-paper'; const CBox = (props) => { // Method passed through props to update parent's state const { onPress } = props; const [checked, setChecked] = React.useState(false); return ( <Checkbox status={checked ? 'checked' : 'unchecked'} color="#FF7000" onPress={() => { // Return state to method (set passed through props) onPress(!checked), // Update state setChecked(!checked) }} /> ); }; export default CBox;
With this code, the check doesn’t show the checkbox box:
iOS:
Since we want the checkbox box to be displayed the same way as on Android, we need to modify it as follows:
Simply change the <Checkbox tag to <Checkbox.Android
import React from "react"; import { Checkbox } from 'react-native-paper'; const CBox = (props) => { // Method passed through props to update parent's state const { onPress } = props; const [checked, setChecked] = React.useState(false); return ( <Checkbox.Android status={checked ? 'checked' : 'unchecked'} color="#FF7000" onPress={() => { // Return state to method (set passed through props) onPress(!checked), // Update state setChecked(!checked) }} /> ); }; export default CBox;
Now, we can see that the checkbox box is displayed:
data:image/s3,"s3://crabby-images/455bc/455bc07dff9acb122aa29eb06fb42d02dc40db39" alt=""
When implementing a checkbox from the React Native Paper Checkbox library in Android, the element appears correctly, but in iOS, the checkbox box is not displayed:
iOS Display:
data:image/s3,"s3://crabby-images/18bfc/18bfc68bff4e05bb9d6efd0f1d824abd5bb19b8f" alt=""
Android Display:
data:image/s3,"s3://crabby-images/ccd10/ccd1013c7853fe0786d7b1fabdfb31106e24a5ed" alt=""
If we look at the documentation (React Native Paper Checkbox), it indicates that the checkbox boxes appear on Android but not on iOS:
data:image/s3,"s3://crabby-images/b2f65/b2f6521a906d7894e33bd360eaadc223bd2eea03" alt=""
To fix this and make the checkbox boxes appear the same way on iOS as they do on Android, you need to do the following:
Starting with this code where it displays correctly on Android:
import React from "react"; import { Checkbox } from 'react-native-paper'; const CBox = (props) => { // Method passed through props to update parent's state const { onPress } = props; const [checked, setChecked] = React.useState(false); return ( <Checkbox status={checked ? 'checked' : 'unchecked'} color="#FF7000" onPress={() => { // Return state to method (set passed through props) onPress(!checked), // Update state setChecked(!checked) }} /> ); }; export default CBox;
With this code, the checkbox boxes are not displayed on iOS:
To make the checkbox boxes appear the same way on iOS as they do on Android, modify the code as follows:
Simply change the <Checkbox tag to <Checkbox.Android
import React from "react"; import { Checkbox } from 'react-native-paper'; const CBox = (props) => { // Method passed through props to update parent's state const { onPress } = props; const [checked, setChecked] = React.useState(false); return ( <Checkbox.Android status={checked ? 'checked' : 'unchecked'} color="#FF7000" onPress={() => { // Return state to method (set passed through props) onPress(!checked), // Update state setChecked(!checked) }} /> ); }; export default CBox;
Now, the checkbox boxes are displayed as expected on iOS:
I hope you find this helpful. Have a great day! :winking_face:
data:image/s3,"s3://crabby-images/dcda1/dcda1869d3b0ea466fe645d8fc18f277ea25d855" alt=""