diff options
author | Paul Frazee <pfrazee@gmail.com> | 2023-11-08 09:38:28 -0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2023-11-08 09:38:28 -0800 |
commit | 5843e212c0ebbfc6c3831929bbbaa72e1a289aba (patch) | |
tree | 08b6beed54700c56b65edbff32dc32baae0a4208 /src/view/com/modals/lang-settings/PostLanguagesSettings.tsx | |
parent | e75b2d508baf9b19e7340657ac2951e9f057b735 (diff) | |
download | voidsky-5843e212c0ebbfc6c3831929bbbaa72e1a289aba.tar.zst |
Move language preferences to new persistence + context (#1837)
Diffstat (limited to 'src/view/com/modals/lang-settings/PostLanguagesSettings.tsx')
-rw-r--r-- | src/view/com/modals/lang-settings/PostLanguagesSettings.tsx | 25 |
1 files changed, 15 insertions, 10 deletions
diff --git a/src/view/com/modals/lang-settings/PostLanguagesSettings.tsx b/src/view/com/modals/lang-settings/PostLanguagesSettings.tsx index d74d884cc..435fb9e1a 100644 --- a/src/view/com/modals/lang-settings/PostLanguagesSettings.tsx +++ b/src/view/com/modals/lang-settings/PostLanguagesSettings.tsx @@ -10,11 +10,19 @@ import {deviceLocales} from 'platform/detection' import {LANGUAGES, LANGUAGES_MAP_CODE2} from '../../../../locale/languages' import {ConfirmLanguagesButton} from './ConfirmLanguagesButton' import {ToggleButton} from 'view/com/util/forms/ToggleButton' +import { + useLanguagePrefs, + useSetLanguagePrefs, + hasPostLanguage, + togglePostLanguage, +} from '#/state/preferences/languages' export const snapPoints = ['100%'] export const Component = observer(function PostLanguagesSettingsImpl() { const store = useStores() + const langPrefs = useLanguagePrefs() + const setLangPrefs = useSetLanguagePrefs() const pal = usePalette('default') const {isMobile} = useWebMediaQueries() const onPressDone = React.useCallback(() => { @@ -30,23 +38,23 @@ export const Component = observer(function PostLanguagesSettingsImpl() { // sort so that device & selected languages are on top, then alphabetically langs.sort((a, b) => { const hasA = - store.preferences.hasPostLanguage(a.code2) || + hasPostLanguage(langPrefs.postLanguage, a.code2) || deviceLocales.includes(a.code2) const hasB = - store.preferences.hasPostLanguage(b.code2) || + hasPostLanguage(langPrefs.postLanguage, b.code2) || deviceLocales.includes(b.code2) if (hasA === hasB) return a.name.localeCompare(b.name) if (hasA) return -1 return 1 }) return langs - }, [store]) + }, [langPrefs]) const onPress = React.useCallback( (code2: string) => { - store.preferences.togglePostLanguage(code2) + togglePostLanguage(langPrefs, setLangPrefs, code2) }, - [store], + [langPrefs, setLangPrefs], ) return ( @@ -70,14 +78,11 @@ export const Component = observer(function PostLanguagesSettingsImpl() { </Text> <ScrollView style={styles.scrollContainer}> {languages.map(lang => { - const isSelected = store.preferences.hasPostLanguage(lang.code2) + const isSelected = hasPostLanguage(langPrefs.postLanguage, lang.code2) // enforce a max of 3 selections for post languages let isDisabled = false - if ( - store.preferences.postLanguage.split(',').length >= 3 && - !isSelected - ) { + if (langPrefs.postLanguage.split(',').length >= 3 && !isSelected) { isDisabled = true } |