import React from 'react' import {StyleSheet, View} from 'react-native' import {Trans} from '@lingui/macro' import {usePalette} from '#/lib/hooks/usePalette' import {useWebMediaQueries} from '#/lib/hooks/useWebMediaQueries' import {deviceLanguageCodes} from '#/locale/deviceLocales' import {useModalControls} from '#/state/modals' import { useLanguagePrefs, useLanguagePrefsApi, } from '#/state/preferences/languages' import {LANGUAGES, LANGUAGES_MAP_CODE2} from '../../../../locale/languages' import {Text} from '../../util/text/Text' import {ScrollView} from '../util' import {ConfirmLanguagesButton} from './ConfirmLanguagesButton' import {LanguageToggle} from './LanguageToggle' export const snapPoints = ['100%'] export function Component({}: {}) { const {closeModal} = useModalControls() const langPrefs = useLanguagePrefs() const setLangPrefs = useLanguagePrefsApi() const pal = usePalette('default') const {isMobile} = useWebMediaQueries() const onPressDone = React.useCallback(() => { closeModal() }, [closeModal]) const languages = React.useMemo(() => { const langs = LANGUAGES.filter( lang => !!lang.code2.trim() && LANGUAGES_MAP_CODE2[lang.code2].code3 === lang.code3, ) // sort so that device & selected languages are on top, then alphabetically langs.sort((a, b) => { const hasA = langPrefs.contentLanguages.includes(a.code2) || deviceLanguageCodes.includes(a.code2) const hasB = langPrefs.contentLanguages.includes(b.code2) || deviceLanguageCodes.includes(b.code2) if (hasA === hasB) return a.name.localeCompare(b.name) if (hasA) return -1 return 1 }) return langs }, [langPrefs]) const onPress = React.useCallback( (code2: string) => { setLangPrefs.toggleContentLanguage(code2) }, [setLangPrefs], ) return ( Content Languages Which languages would you like to see in your algorithmic feeds? Leave them all unchecked to see any language. {languages.map(lang => ( { onPress(lang.code2) }} /> ))} ) } const styles = StyleSheet.create({ container: { flex: 1, }, title: { textAlign: 'center', fontWeight: '600', fontSize: 24, marginBottom: 12, }, description: { textAlign: 'center', paddingHorizontal: 16, marginBottom: 10, }, scrollContainer: { flex: 1, paddingHorizontal: 10, }, })