mirror of
https://github.com/laurent22/joplin.git
synced 2024-12-24 10:27:10 +02:00
46 lines
1.1 KiB
TypeScript
46 lines
1.1 KiB
TypeScript
|
import * as React from 'react';
|
||
|
import { FunctionComponent, ReactNode } from 'react';
|
||
|
|
||
|
import { View, Text, Switch } from 'react-native';
|
||
|
import { UpdateSettingValueCallback } from './types';
|
||
|
import { themeStyle } from '@joplin/lib/theme';
|
||
|
import { ConfigScreenStyles } from './configScreenStyles';
|
||
|
|
||
|
interface Props {
|
||
|
settingId: string;
|
||
|
value: any;
|
||
|
|
||
|
themeId: number;
|
||
|
styles: ConfigScreenStyles;
|
||
|
|
||
|
label: string;
|
||
|
updateSettingValue: UpdateSettingValueCallback;
|
||
|
|
||
|
description?: ReactNode;
|
||
|
}
|
||
|
|
||
|
const SettingsToggle: FunctionComponent<Props> = props => {
|
||
|
const theme = themeStyle(props.themeId);
|
||
|
const styleSheet = props.styles.styleSheet;
|
||
|
|
||
|
return (
|
||
|
<View>
|
||
|
<View style={props.styles.getContainerStyle(false)}>
|
||
|
<Text key="label" style={styleSheet.switchSettingText}>
|
||
|
{props.label}
|
||
|
</Text>
|
||
|
<Switch
|
||
|
key="control"
|
||
|
style={styleSheet.switchSettingControl}
|
||
|
trackColor={{ false: theme.dividerColor }}
|
||
|
value={props.value}
|
||
|
onValueChange={(value: boolean) => void props.updateSettingValue(props.settingId, value)}
|
||
|
/>
|
||
|
</View>
|
||
|
{props.description}
|
||
|
</View>
|
||
|
);
|
||
|
};
|
||
|
|
||
|
export default SettingsToggle;
|