import React from 'react'; import { StyleSheet, Text } from 'react-native'; import { StackNavigationOptions, StackNavigationProp } from '@react-navigation/stack'; import { connect } from 'react-redux'; import { themes } from '../../constants/colors'; import StatusBar from '../../containers/StatusBar'; import * as List from '../../containers/List'; import I18n from '../../i18n'; import RocketChat from '../../lib/rocketchat'; import { withTheme } from '../../theme'; import SafeAreaView from '../../containers/SafeAreaView'; import ActivityIndicator from '../../containers/ActivityIndicator'; import { getUserSelector } from '../../selectors/login'; import sharedStyles from '../Styles'; import { OPTIONS } from './options'; const styles = StyleSheet.create({ pickerText: { ...sharedStyles.textRegular, fontSize: 16 } }); type TKey = 'desktopNotifications' | 'mobileNotifications' | 'emailNotificationMode'; interface IUserNotificationPreferencesViewState { preferences: { desktopNotifications?: string; mobileNotifications?: string; emailNotificationMode?: string; }; loading: boolean; } interface IUserNotificationPreferencesViewProps { navigation: StackNavigationProp; theme: string; user: { id: string; }; } class UserNotificationPreferencesView extends React.Component< IUserNotificationPreferencesViewProps, IUserNotificationPreferencesViewState > { static navigationOptions = (): StackNavigationOptions => ({ title: I18n.t('Notification_Preferences') }); constructor(props: IUserNotificationPreferencesViewProps) { super(props); this.state = { preferences: {}, loading: false }; } async componentDidMount() { const { user } = this.props; const { id } = user; const result = await RocketChat.getUserPreferences(id); const { preferences } = result; this.setState({ preferences, loading: true }); } findDefaultOption = (key: TKey) => { const { preferences } = this.state; const option = preferences[key] ? OPTIONS[key].find(item => item.value === preferences[key]) : OPTIONS[key][0]; return option; }; renderPickerOption = (key: TKey) => { const { theme } = this.props; const text = this.findDefaultOption(key); return {I18n.t(text?.label)}; }; pickerSelection = (title: string, key: TKey) => { const { preferences } = this.state; const { navigation } = this.props; let values = OPTIONS[key]; const defaultOption = this.findDefaultOption(key); if (OPTIONS[key][0]?.value !== 'default') { const defaultValue = { label: `${I18n.t('Default')} (${I18n.t(defaultOption?.label)})` } as { label: string; value: string; }; values = [defaultValue, ...OPTIONS[key]]; } navigation.navigate('PickerView', { title, data: values, value: preferences[key], onChangeValue: (value: string) => this.onValueChangePicker(key, value ?? defaultOption?.value) }); }; onValueChangePicker = (key: TKey, value: string) => this.saveNotificationPreferences({ [key]: value.toString() }); saveNotificationPreferences = async (params: { [key: string]: string }) => { const { user } = this.props; const { id } = user; const result = await RocketChat.setUserPreferences(id, params); const { user: { settings } } = result; this.setState({ preferences: settings.preferences }); }; render() { const { theme } = this.props; const { loading } = this.state; return ( {loading ? ( <> this.pickerSelection(title, 'desktopNotifications')} right={() => this.renderPickerOption('desktopNotifications')} /> this.pickerSelection(title, 'mobileNotifications')} right={() => this.renderPickerOption('mobileNotifications')} /> this.pickerSelection(title, 'emailNotificationMode')} right={() => this.renderPickerOption('emailNotificationMode')} /> ) : ( )} ); } } const mapStateToProps = (state: any) => ({ user: getUserSelector(state) }); export default connect(mapStateToProps)(withTheme(UserNotificationPreferencesView));