-
Notifications
You must be signed in to change notification settings - Fork 1.4k
Expand file tree
/
Copy pathindex.tsx
More file actions
119 lines (102 loc) · 3.73 KB
/
index.tsx
File metadata and controls
119 lines (102 loc) · 3.73 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
import React, { useLayoutEffect } from 'react';
import { FlatList } from 'react-native';
import RNRestart from 'react-native-restart';
import { useDispatch } from 'react-redux';
import { useNavigation } from '@react-navigation/native';
import { type NativeStackNavigationProp } from '@react-navigation/native-stack';
import ListRadio from '../../containers/List/ListRadio';
import { useAppSelector } from '../../lib/hooks/useAppSelector';
import { appStart } from '../../actions/app';
import { setUser } from '../../actions/login';
import * as List from '../../containers/List';
import SafeAreaView from '../../containers/SafeAreaView';
import { RootEnum } from '../../definitions';
import I18n, { isRTL, LANGUAGES } from '../../i18n';
import database from '../../lib/database';
import { getUserSelector } from '../../selectors/login';
import { type SettingsStackParamList } from '../../stacks/types';
import { showErrorAlert } from '../../lib/methods/helpers/info';
import log, { events, logEvent } from '../../lib/methods/helpers/log';
import { saveUserPreferences } from '../../lib/services/restApi';
import { getAppTranslations } from '../../lib/methods/getAppTranslations';
const LanguageView = () => {
const { languageDefault, id } = useAppSelector(state => ({
languageDefault: getUserSelector(state).language,
id: getUserSelector(state).id
}));
const language = languageDefault || 'en';
const dispatch = useDispatch();
const navigation = useNavigation<NativeStackNavigationProp<SettingsStackParamList, 'LanguageView'>>();
useLayoutEffect(() => {
navigation.setOptions({
title: I18n.t('Change_Language')
});
}, [navigation]);
const submit = async (language: string) => {
if (languageDefault === language) {
return;
}
const shouldRestart = isRTL(language) || isRTL(languageDefault);
dispatch(appStart({ root: RootEnum.ROOT_LOADING, text: I18n.t('Change_language_loading') }));
// shows loading for at least 300ms
await Promise.all([changeLanguage(language), new Promise(resolve => setTimeout(resolve, 300))]);
if (shouldRestart) {
await RNRestart.Restart();
} else {
dispatch(appStart({ root: RootEnum.ROOT_INSIDE }));
}
};
const changeLanguage = async (language: string) => {
logEvent(events.LANG_SET_LANGUAGE);
const params: { language?: string } = {};
// language
if (languageDefault !== language) {
params.language = language;
}
try {
await saveUserPreferences(params);
dispatch(setUser({ language: params.language }));
const serversDB = database.servers;
const usersCollection = serversDB.get('users');
await serversDB.write(async () => {
try {
const userRecord = await usersCollection.find(id);
await userRecord.update(record => {
record.language = params.language;
});
} catch (e) {
logEvent(events.LANG_SET_LANGUAGE_F);
}
});
const appLang = (params.language || 'en').split('-')[0];
await getAppTranslations(appLang);
} catch (e) {
logEvent(events.LANG_SET_LANGUAGE_F);
showErrorAlert(I18n.t('There_was_an_error_while_action', { action: I18n.t('saving_preferences') }));
log(e);
}
};
return (
<SafeAreaView testID='language-view'>
<FlatList
data={LANGUAGES}
keyExtractor={item => item.value}
ListHeaderComponent={List.Separator}
ListFooterComponent={List.Separator}
contentContainerStyle={List.styles.contentContainerStyleFlatList}
renderItem={({ item }) => (
<ListRadio
testID={`language-view-${item.value}`}
title={item.label}
value={item.value}
translateTitle={false}
isSelected={item.value === (language || languageDefault)}
onPress={() => submit(item.value)}
/>
)}
ItemSeparatorComponent={List.Separator}
/>
</SafeAreaView>
);
};
export default LanguageView;