30 lines
699 B
TypeScript
30 lines
699 B
TypeScript
import React from 'react';
|
|
import { TextInput, StyleSheet, I18nManager } from 'react-native';
|
|
|
|
import { themes } from '../constants/colors';
|
|
|
|
const styles = StyleSheet.create({
|
|
input: {
|
|
...I18nManager.isRTL
|
|
? { textAlign: 'right' }
|
|
: { textAlign: 'left' }
|
|
}
|
|
});
|
|
|
|
interface IThemedTextInput {
|
|
style: object;
|
|
theme: string;
|
|
}
|
|
|
|
const ThemedTextInput = React.forwardRef(({ style, theme, ...props }: IThemedTextInput, ref: any) => (
|
|
<TextInput
|
|
ref={ref}
|
|
style={[{ color: themes[theme].titleText }, style, styles.input]}
|
|
placeholderTextColor={themes[theme].auxiliaryText}
|
|
keyboardAppearance={theme === 'light' ? 'light' : 'dark'}
|
|
{...props}
|
|
/>
|
|
));
|
|
|
|
export default ThemedTextInput;
|