feat: language selection on mobile
This commit is contained in:
		
							parent
							
								
									50fac73713
								
							
						
					
					
						commit
						aa43e4cd4e
					
				
					 1 changed files with 75 additions and 1 deletions
				
			
		|  | @ -9,6 +9,14 @@ import {Trans, msg} from '@lingui/macro' | ||||||
| import {useLingui} from '@lingui/react' | import {useLingui} from '@lingui/react' | ||||||
| import {Logo} from '#/view/icons/Logo' | import {Logo} from '#/view/icons/Logo' | ||||||
| import {Logotype} from '#/view/icons/Logotype' | import {Logotype} from '#/view/icons/Logotype' | ||||||
|  | import { | ||||||
|  |   FontAwesomeIcon, | ||||||
|  |   FontAwesomeIconStyle, | ||||||
|  | } from '@fortawesome/react-native-fontawesome' | ||||||
|  | import RNPickerSelect, {PickerSelectProps} from 'react-native-picker-select' | ||||||
|  | import {sanitizeAppLanguageSetting} from '#/locale/helpers' | ||||||
|  | import {useLanguagePrefs, useLanguagePrefsApi} from '#/state/preferences' | ||||||
|  | import {APP_LANGUAGES} from '#/locale/languages' | ||||||
| 
 | 
 | ||||||
| export const SplashScreen = ({ | export const SplashScreen = ({ | ||||||
|   onPressSignin, |   onPressSignin, | ||||||
|  | @ -20,6 +28,21 @@ export const SplashScreen = ({ | ||||||
|   const pal = usePalette('default') |   const pal = usePalette('default') | ||||||
|   const {_} = useLingui() |   const {_} = useLingui() | ||||||
| 
 | 
 | ||||||
|  |   const langPrefs = useLanguagePrefs() | ||||||
|  |   const setLangPrefs = useLanguagePrefsApi() | ||||||
|  | 
 | ||||||
|  |   const sanitizedLang = sanitizeAppLanguageSetting(langPrefs.appLanguage) | ||||||
|  | 
 | ||||||
|  |   const onChangeAppLanguage = React.useCallback( | ||||||
|  |     (value: Parameters<PickerSelectProps['onValueChange']>[0]) => { | ||||||
|  |       if (!value) return | ||||||
|  |       if (sanitizedLang !== value) { | ||||||
|  |         setLangPrefs.setAppLanguage(sanitizeAppLanguageSetting(value)) | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     [sanitizedLang, setLangPrefs], | ||||||
|  |   ) | ||||||
|  | 
 | ||||||
|   return ( |   return ( | ||||||
|     <CenteredView style={[styles.container, pal.view]}> |     <CenteredView style={[styles.container, pal.view]}> | ||||||
|       <ErrorBoundary> |       <ErrorBoundary> | ||||||
|  | @ -58,6 +81,51 @@ export const SplashScreen = ({ | ||||||
|             </Text> |             </Text> | ||||||
|           </TouchableOpacity> |           </TouchableOpacity> | ||||||
|         </View> |         </View> | ||||||
|  |         <View style={styles.footer}> | ||||||
|  |           <View style={{position: 'relative'}}> | ||||||
|  |             <RNPickerSelect | ||||||
|  |               placeholder={{}} | ||||||
|  |               value={sanitizedLang} | ||||||
|  |               onValueChange={onChangeAppLanguage} | ||||||
|  |               items={APP_LANGUAGES.filter(l => Boolean(l.code2)).map(l => ({ | ||||||
|  |                 label: l.name, | ||||||
|  |                 value: l.code2, | ||||||
|  |                 key: l.code2, | ||||||
|  |               }))} | ||||||
|  |               useNativeAndroidPickerStyle={false} | ||||||
|  |               style={{ | ||||||
|  |                 inputAndroid: { | ||||||
|  |                   color: pal.textLight.color, | ||||||
|  |                   fontSize: 16, | ||||||
|  |                   paddingRight: 10 + 4, | ||||||
|  |                 }, | ||||||
|  |                 inputIOS: { | ||||||
|  |                   color: pal.text.color, | ||||||
|  |                   fontSize: 14, | ||||||
|  |                   paddingRight: 10 + 4, | ||||||
|  |                 }, | ||||||
|  |               }} | ||||||
|  |             /> | ||||||
|  | 
 | ||||||
|  |             <View | ||||||
|  |               style={{ | ||||||
|  |                 position: 'absolute', | ||||||
|  |                 top: 0, | ||||||
|  |                 right: 0, | ||||||
|  |                 bottom: 0, | ||||||
|  |                 width: 10, | ||||||
|  |                 pointerEvents: 'none', | ||||||
|  |                 alignItems: 'center', | ||||||
|  |                 justifyContent: 'center', | ||||||
|  |               }}> | ||||||
|  |               <FontAwesomeIcon | ||||||
|  |                 icon="chevron-down" | ||||||
|  |                 size={10} | ||||||
|  |                 style={pal.textLight as FontAwesomeIconStyle} | ||||||
|  |               /> | ||||||
|  |             </View> | ||||||
|  |           </View> | ||||||
|  |         </View> | ||||||
|       </ErrorBoundary> |       </ErrorBoundary> | ||||||
|     </CenteredView> |     </CenteredView> | ||||||
|   ) |   ) | ||||||
|  | @ -73,7 +141,7 @@ const styles = StyleSheet.create({ | ||||||
|     alignItems: 'center', |     alignItems: 'center', | ||||||
|   }, |   }, | ||||||
|   btns: { |   btns: { | ||||||
|     paddingBottom: 40, |     paddingBottom: 0, | ||||||
|   }, |   }, | ||||||
|   title: { |   title: { | ||||||
|     textAlign: 'center', |     textAlign: 'center', | ||||||
|  | @ -95,4 +163,10 @@ const styles = StyleSheet.create({ | ||||||
|     textAlign: 'center', |     textAlign: 'center', | ||||||
|     fontSize: 21, |     fontSize: 21, | ||||||
|   }, |   }, | ||||||
|  |   footer: { | ||||||
|  |     paddingHorizontal: 16, | ||||||
|  |     paddingVertical: 12, | ||||||
|  |     justifyContent: 'center', | ||||||
|  |     alignItems: 'center', | ||||||
|  |   }, | ||||||
| }) | }) | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue