mirror of
https://github.com/laurent22/joplin.git
synced 2025-01-23 18:53:36 +02:00
68 lines
1.6 KiB
TypeScript
68 lines
1.6 KiB
TypeScript
import * as React from 'react';
|
|
import { useState, useEffect, useCallback, useMemo } from 'react';
|
|
import { TouchableHighlight, StyleSheet, TextStyle } from 'react-native';
|
|
const Icon = require('react-native-vector-icons/Ionicons').default;
|
|
|
|
interface Props {
|
|
checked: boolean;
|
|
accessibilityLabel?: string;
|
|
onChange?: (checked: boolean)=> void;
|
|
style?: TextStyle;
|
|
iconStyle?: TextStyle;
|
|
}
|
|
|
|
const useStyles = (baseStyles: TextStyle|undefined, iconStyle: TextStyle|undefined) => {
|
|
return useMemo(() => {
|
|
return StyleSheet.create({
|
|
container: {
|
|
...(baseStyles ?? {}),
|
|
justifyContent: 'center',
|
|
alignItems: 'center',
|
|
},
|
|
icon: {
|
|
fontSize: 20,
|
|
height: 22,
|
|
color: baseStyles?.color,
|
|
...iconStyle,
|
|
},
|
|
});
|
|
}, [baseStyles, iconStyle]);
|
|
};
|
|
|
|
const Checkbox: React.FC<Props> = props => {
|
|
const [checked, setChecked] = useState(props.checked);
|
|
|
|
useEffect(() => {
|
|
setChecked(props.checked);
|
|
}, [props.checked]);
|
|
|
|
const onPress = useCallback(() => {
|
|
setChecked(checked => {
|
|
const newChecked = !checked;
|
|
props.onChange?.(newChecked);
|
|
return newChecked;
|
|
});
|
|
}, [props.onChange]);
|
|
|
|
const iconName = checked ? 'checkbox-outline' : 'square-outline';
|
|
const styles = useStyles(props.style, props.iconStyle);
|
|
|
|
const accessibilityState = useMemo(() => ({
|
|
checked,
|
|
}), [checked]);
|
|
|
|
return (
|
|
<TouchableHighlight
|
|
onPress={onPress}
|
|
style={styles.container}
|
|
accessibilityRole="checkbox"
|
|
accessibilityState={accessibilityState}
|
|
accessibilityLabel={props.accessibilityLabel ?? ''}
|
|
>
|
|
<Icon name={iconName} style={styles.icon} />
|
|
</TouchableHighlight>
|
|
);
|
|
};
|
|
|
|
export default Checkbox;
|