import React from 'react'; import { FlatList, StyleSheet, Switch } from 'react-native'; import { RouteProp } from '@react-navigation/core'; import { ChatsStackParamList } from '../../stacks/types'; import RocketChat from '../../lib/rocketchat'; import I18n from '../../i18n'; import StatusBar from '../../containers/StatusBar'; import * as List from '../../containers/List'; import { SWITCH_TRACK_COLOR, themes } from '../../constants/colors'; import { withTheme } from '../../theme'; import SafeAreaView from '../../containers/SafeAreaView'; import { events, logEvent } from '../../utils/log'; import { ISubscription } from '../../definitions/ISubscription'; const styles = StyleSheet.create({ list: { paddingTop: 16 } }); interface IAutoTranslateViewProps { route: RouteProp; theme: string; } class AutoTranslateView extends React.Component { static navigationOptions = () => ({ title: I18n.t('Auto_Translate') }); private mounted: boolean; private rid: string | undefined; private roomObservable: any; private subscription: any; constructor(props: IAutoTranslateViewProps) { super(props); this.mounted = false; this.rid = props.route.params?.rid; const room = props.route.params?.room; if (room && room.observe) { this.roomObservable = room.observe(); this.subscription = this.roomObservable.subscribe((changes: ISubscription) => { if (this.mounted) { const { selectedLanguage, enableAutoTranslate } = this.state; if (selectedLanguage !== changes.autoTranslateLanguage) { this.setState({ selectedLanguage: changes.autoTranslateLanguage }); } if (enableAutoTranslate !== changes.autoTranslate) { this.setState({ enableAutoTranslate: changes.autoTranslate }); } } }); } this.state = { languages: [], selectedLanguage: room?.autoTranslateLanguage, enableAutoTranslate: room?.autoTranslate }; } async componentDidMount() { this.mounted = true; try { const languages = await RocketChat.getSupportedLanguagesAutoTranslate(); this.setState({ languages }); } catch (error) { console.log(error); } } componentWillUnmount() { if (this.subscription && this.subscription.unsubscribe) { this.subscription.unsubscribe(); } } toggleAutoTranslate = async () => { logEvent(events.AT_TOGGLE_TRANSLATE); const { enableAutoTranslate } = this.state; try { await RocketChat.saveAutoTranslate({ rid: this.rid, field: 'autoTranslate', value: enableAutoTranslate ? '0' : '1', options: { defaultLanguage: 'en' } }); this.setState({ enableAutoTranslate: !enableAutoTranslate }); } catch (error) { logEvent(events.AT_TOGGLE_TRANSLATE_F); console.log(error); } }; saveAutoTranslateLanguage = async (language: string) => { logEvent(events.AT_SET_LANG); try { // TODO: remove the parameter options, after migrate the RocketChat await RocketChat.saveAutoTranslate({ rid: this.rid, field: 'autoTranslateLanguage', value: language, options: null }); this.setState({ selectedLanguage: language }); } catch (error) { logEvent(events.AT_SET_LANG_F); console.log(error); } }; renderIcon = () => { const { theme } = this.props; return ; }; renderSwitch = () => { const { enableAutoTranslate } = this.state; return ; }; renderItem = ({ item }: { item: { language: string; name: string } }) => { const { selectedLanguage } = this.state; const { language, name } = item; const isSelected = selectedLanguage === language; return ( this.saveAutoTranslateLanguage(language)} testID={`auto-translate-view-${language}`} right={isSelected ? this.renderIcon : null} translateTitle={false} /> ); }; render() { const { languages } = this.state; return ( this.renderSwitch()} /> item.language} renderItem={this.renderItem} ItemSeparatorComponent={List.Separator} ListFooterComponent={List.Separator} ListHeaderComponent={List.Separator} contentContainerStyle={[List.styles.contentContainerStyleFlatList, styles.list]} /> ); } } export default withTheme(AutoTranslateView);