import React from 'react' import {StyleSheet, View} from 'react-native' import {observer} from 'mobx-react-lite' import {ScrollView} from '../util' import {useStores} from 'state/index' import {Text} from '../../util/text/Text' import {usePalette} from 'lib/hooks/usePalette' import {isDesktopWeb, deviceLocales} from 'platform/detection' import {LANGUAGES, LANGUAGES_MAP_CODE2} from '../../../../locale/languages' import {ConfirmLanguagesButton} from './ConfirmLanguagesButton' import {ToggleButton} from 'view/com/util/forms/ToggleButton' export const snapPoints = ['100%'] export const Component = observer(() => { const store = useStores() const pal = usePalette('default') const onPressDone = React.useCallback(() => { store.shell.closeModal() }, [store]) 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 = store.preferences.hasPostLanguage(a.code2) || deviceLocales.includes(a.code2) const hasB = store.preferences.hasPostLanguage(b.code2) || deviceLocales.includes(b.code2) if (hasA === hasB) return a.name.localeCompare(b.name) if (hasA) return -1 return 1 }) return langs }, [store]) const onPress = React.useCallback( (code2: string) => { store.preferences.togglePostLanguage(code2) }, [store], ) return ( Post Languages Which languages are used in this post? {languages.map(lang => { const isSelected = store.preferences.hasPostLanguage(lang.code2) // enforce a max of 3 selections for post languages let isDisabled = false if ( store.preferences.postLanguage.split(',').length >= 3 && !isSelected ) { isDisabled = true } return ( (isDisabled ? undefined : onPress(lang.code2))} style={[ pal.border, styles.languageToggle, isDisabled && styles.dimmed, ]} /> ) })} ) }) const styles = StyleSheet.create({ container: { flex: 1, paddingTop: 20, }, title: { textAlign: 'center', fontWeight: 'bold', fontSize: 24, marginBottom: 12, }, description: { textAlign: 'center', paddingHorizontal: 16, marginBottom: 10, }, scrollContainer: { flex: 1, paddingHorizontal: 10, }, bottomSpacer: { height: isDesktopWeb ? 0 : 60, }, languageToggle: { borderTopWidth: 1, borderRadius: 0, paddingHorizontal: 6, paddingVertical: 12, }, dimmed: { opacity: 0.5, }, })