您最多选择25个主题 主题必须以字母或数字开头,可以包含连字符 (-),并且长度不得超过35个字符

LanguageListItem.tsx 1.8KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. import React, { useCallback } from 'react';
  2. import { WithTranslation } from 'react-i18next';
  3. import { StyleProp, TouchableHighlight, View, ViewStyle } from 'react-native';
  4. import { Text } from 'react-native-paper';
  5. import { translate } from '../../../base/i18n/functions';
  6. import Icon from '../../../base/icons/components/Icon';
  7. import { IconCheck } from '../../../base/icons/svg';
  8. import styles from './styles';
  9. interface ILanguageListItemProps extends WithTranslation {
  10. /**
  11. * Language string.
  12. */
  13. lang: string;
  14. /**
  15. * Callback for language selection.
  16. */
  17. onLanguageSelected: (lang: string) => void;
  18. /**
  19. * If language item is selected or not.
  20. */
  21. selected?: boolean;
  22. }
  23. /**
  24. * Component that renders the language list item.
  25. *
  26. * @returns {React$Element<any>}
  27. */
  28. const LanguageListItem = ({ t, lang, selected, onLanguageSelected
  29. }: ILanguageListItemProps) => {
  30. const onLanguageSelectedWrapper
  31. = useCallback(() => onLanguageSelected(lang), [ lang ]);
  32. return (
  33. <View style = { styles.languageItemWrapper as StyleProp<ViewStyle> }>
  34. <View style = { styles.iconWrapper }>
  35. {
  36. selected
  37. && <Icon
  38. size = { 20 }
  39. src = { IconCheck } />
  40. }
  41. </View>
  42. <TouchableHighlight
  43. onPress = { onLanguageSelectedWrapper }
  44. underlayColor = { 'transparent' } >
  45. <Text
  46. style = { [
  47. styles.languageItemText,
  48. selected && styles.activeLanguageItemText ] }>
  49. { t(lang) }
  50. </Text>
  51. </TouchableHighlight>
  52. </View>
  53. );
  54. };
  55. export default translate(LanguageListItem);