Mark more texts for localization
This commit is contained in:
		
							parent
							
								
									836cff306e
								
							
						
					
					
						commit
						3f5bdd8be3
					
				
					 27 changed files with 127 additions and 93 deletions
				
			
		|  | @ -52,7 +52,9 @@ export function HomeLoggedOutCTA() { | |||
|           onPress={showCreateAccount} | ||||
|           accessibilityRole="button" | ||||
|           accessibilityLabel={_(msg`Create new account`)} | ||||
|           accessibilityHint="Opens flow to create a new Bluesky account"> | ||||
|           accessibilityHint={_( | ||||
|             msg`Opens flow to create a new Bluesky account`, | ||||
|           )}> | ||||
|           <Text | ||||
|             style={[ | ||||
|               s.white, | ||||
|  | @ -68,7 +70,9 @@ export function HomeLoggedOutCTA() { | |||
|           onPress={showSignIn} | ||||
|           accessibilityRole="button" | ||||
|           accessibilityLabel={_(msg`Sign in`)} | ||||
|           accessibilityHint="Opens flow to sign into your existing Bluesky account"> | ||||
|           accessibilityHint={_( | ||||
|             msg`Opens flow to sign into your existing Bluesky account`, | ||||
|           )}> | ||||
|           <Text | ||||
|             style={[ | ||||
|               pal.text, | ||||
|  |  | |||
|  | @ -66,7 +66,9 @@ export const SplashScreen = ({ | |||
|             onPress={onPressCreateAccount} | ||||
|             accessibilityRole="button" | ||||
|             accessibilityLabel={_(msg`Create new account`)} | ||||
|             accessibilityHint="Opens flow to create a new Bluesky account"> | ||||
|             accessibilityHint={_( | ||||
|               msg`Opens flow to create a new Bluesky account`, | ||||
|             )}> | ||||
|             <Text style={[s.white, styles.btnLabel]}> | ||||
|               <Trans>Create a new account</Trans> | ||||
|             </Text> | ||||
|  | @ -77,7 +79,9 @@ export const SplashScreen = ({ | |||
|             onPress={onPressSignin} | ||||
|             accessibilityRole="button" | ||||
|             accessibilityLabel={_(msg`Sign in`)} | ||||
|             accessibilityHint="Opens flow to sign into your existing Bluesky account"> | ||||
|             accessibilityHint={_( | ||||
|               msg`Opens flow to sign into your existing Bluesky account`, | ||||
|             )}> | ||||
|             <Text style={[pal.text, styles.btnLabel]}> | ||||
|               <Trans>Sign In</Trans> | ||||
|             </Text> | ||||
|  |  | |||
|  | @ -9,6 +9,8 @@ import {TextLink} from '../../util/Link' | |||
| import {Text} from '../../util/text/Text' | ||||
| import {s, colors} from 'lib/styles' | ||||
| import {usePalette} from 'lib/hooks/usePalette' | ||||
| import {Trans, msg} from '@lingui/macro' | ||||
| import {useLingui} from '@lingui/react' | ||||
| 
 | ||||
| type ServiceDescription = ComAtprotoServerDescribeServer.OutputSchema | ||||
| 
 | ||||
|  | @ -20,6 +22,7 @@ export const Policies = ({ | |||
|   needsGuardian: boolean | ||||
| }) => { | ||||
|   const pal = usePalette('default') | ||||
|   const {_} = useLingui() | ||||
|   if (!serviceDescription) { | ||||
|     return <View /> | ||||
|   } | ||||
|  | @ -40,7 +43,9 @@ export const Policies = ({ | |||
|           /> | ||||
|         </View> | ||||
|         <Text style={[pal.textLight, s.pl5, s.flex1]}> | ||||
|           This service has not provided terms of service or a privacy policy. | ||||
|           <Trans> | ||||
|             This service has not provided terms of service or a privacy policy. | ||||
|           </Trans> | ||||
|         </Text> | ||||
|       </View> | ||||
|     ) | ||||
|  | @ -51,7 +56,7 @@ export const Policies = ({ | |||
|       <TextLink | ||||
|         key="tos" | ||||
|         href={tos} | ||||
|         text="Terms of Service" | ||||
|         text={_(msg`Terms of Service`)} | ||||
|         style={[pal.link, s.underline]} | ||||
|       />, | ||||
|     ) | ||||
|  | @ -61,7 +66,7 @@ export const Policies = ({ | |||
|       <TextLink | ||||
|         key="pp" | ||||
|         href={pp} | ||||
|         text="Privacy Policy" | ||||
|         text={_(msg`Privacy Policy`)} | ||||
|         style={[pal.link, s.underline]} | ||||
|       />, | ||||
|     ) | ||||
|  | @ -79,12 +84,14 @@ export const Policies = ({ | |||
|   return ( | ||||
|     <View style={styles.policies}> | ||||
|       <Text style={pal.textLight}> | ||||
|         By creating an account you agree to the {els}. | ||||
|         <Trans>By creating an account you agree to the {els}.</Trans> | ||||
|       </Text> | ||||
|       {needsGuardian && ( | ||||
|         <Text style={[pal.textLight, s.bold]}> | ||||
|           If you are not yet an adult according to the laws of your country, | ||||
|           your parent or legal guardian must read these Terms on your behalf. | ||||
|           <Trans> | ||||
|             If you are not yet an adult according to the laws of your country, | ||||
|             your parent or legal guardian must read these Terms on your behalf. | ||||
|           </Trans> | ||||
|         </Text> | ||||
|       )} | ||||
|     </View> | ||||
|  |  | |||
|  | @ -30,7 +30,7 @@ export function Step3({ | |||
|         <TextInput | ||||
|           testID="handleInput" | ||||
|           icon="at" | ||||
|           placeholder="e.g. alice" | ||||
|           placeholder={_(msg`e.g. alice`)} | ||||
|           value={uiState.handle} | ||||
|           editable | ||||
|           autoFocus | ||||
|  |  | |||
|  | @ -207,7 +207,7 @@ export const LoginForm = ({ | |||
|             testID="loginPasswordInput" | ||||
|             ref={passwordInputRef} | ||||
|             style={[pal.text, styles.textInput]} | ||||
|             placeholder="Password" | ||||
|             placeholder={_(msg`Password`)} | ||||
|             placeholderTextColor={pal.colors.textLight} | ||||
|             autoCapitalize="none" | ||||
|             autoCorrect={false} | ||||
|  |  | |||
|  | @ -11,7 +11,8 @@ import {Text} from 'view/com/util/text/Text' | |||
| import Animated, {FadeInRight} from 'react-native-reanimated' | ||||
| import {useWebMediaQueries} from 'lib/hooks/useWebMediaQueries' | ||||
| import {useAnalytics} from 'lib/analytics/analytics' | ||||
| import {Trans} from '@lingui/macro' | ||||
| import {useLingui} from '@lingui/react' | ||||
| import {Trans, msg} from '@lingui/macro' | ||||
| import {Shadow, useProfileShadow} from '#/state/cache/profile-shadow' | ||||
| import {useProfileFollowMutationQueue} from '#/state/queries/profile' | ||||
| import {logger} from '#/logger' | ||||
|  | @ -70,6 +71,7 @@ export function ProfileCard({ | |||
| }) { | ||||
|   const {track} = useAnalytics() | ||||
|   const pal = usePalette('default') | ||||
|   const {_} = useLingui() | ||||
|   const [addingMoreSuggestions, setAddingMoreSuggestions] = | ||||
|     React.useState(false) | ||||
|   const [queueFollow, queueUnfollow] = useProfileFollowMutationQueue(profile) | ||||
|  | @ -133,7 +135,7 @@ export function ProfileCard({ | |||
|           type={profile.viewer?.following ? 'default' : 'inverted'} | ||||
|           labelStyle={styles.followButton} | ||||
|           onPress={onToggleFollow} | ||||
|           label={profile.viewer?.following ? 'Unfollow' : 'Follow'} | ||||
|           label={profile.viewer?.following ? _(msg`Unfollow`) : _(msg`Follow`)} | ||||
|         /> | ||||
|       </View> | ||||
|       {profile.description ? ( | ||||
|  |  | |||
|  | @ -6,7 +6,8 @@ import {usePalette} from 'lib/hooks/usePalette' | |||
| import {FontAwesomeIcon} from '@fortawesome/react-native-fontawesome' | ||||
| import {Button} from 'view/com/util/forms/Button' | ||||
| import {ViewHeader} from 'view/com/util/ViewHeader' | ||||
| import {Trans} from '@lingui/macro' | ||||
| import {useLingui} from '@lingui/react' | ||||
| import {Trans, msg} from '@lingui/macro' | ||||
| 
 | ||||
| type Props = { | ||||
|   next: () => void | ||||
|  | @ -15,6 +16,7 @@ type Props = { | |||
| 
 | ||||
| export function WelcomeMobile({next, skip}: Props) { | ||||
|   const pal = usePalette('default') | ||||
|   const {_} = useLingui() | ||||
| 
 | ||||
|   return ( | ||||
|     <View style={[styles.container]} testID="welcomeOnboarding"> | ||||
|  | @ -91,7 +93,7 @@ export function WelcomeMobile({next, skip}: Props) { | |||
| 
 | ||||
|       <Button | ||||
|         onPress={next} | ||||
|         label="Continue" | ||||
|         label={_(msg`Continue`)} | ||||
|         testID="continueBtn" | ||||
|         style={[styles.buttonContainer]} | ||||
|         labelStyle={styles.buttonText} | ||||
|  |  | |||
|  | @ -115,7 +115,7 @@ export function ServerInputDialog({ | |||
|                   testID="customServerTextInput" | ||||
|                   value={customAddress} | ||||
|                   onChangeText={setCustomAddress} | ||||
|                   label={_(msg`my-server.com`)} | ||||
|                   label="my-server.com" | ||||
|                   accessibilityLabelledBy="address-input-label" | ||||
|                   autoCapitalize="none" | ||||
|                   keyboardType="url" | ||||
|  |  | |||
|  | @ -78,9 +78,9 @@ function LightboxFooter({imageIndex}: {imageIndex: number}) { | |||
| 
 | ||||
|       try { | ||||
|         await saveImageToMediaLibrary({uri}) | ||||
|         Toast.show('Saved to your camera roll.') | ||||
|         Toast.show(_(msg`Saved to your camera roll.`)) | ||||
|       } catch (e: any) { | ||||
|         Toast.show(`Failed to save image: ${String(e)}`) | ||||
|         Toast.show(_(msg`Failed to save image: ${String(e)}`)) | ||||
|       } | ||||
|     }, | ||||
|     [permissionResponse, requestPermission, _], | ||||
|  |  | |||
|  | @ -150,7 +150,7 @@ export function Inner({ | |||
|             accessibilityHint={_(msg`Exits handle change process`)} | ||||
|             onAccessibilityEscape={onPressCancel}> | ||||
|             <Text type="lg" style={pal.textLight}> | ||||
|               Cancel | ||||
|               <Trans>Cancel</Trans> | ||||
|             </Text> | ||||
|           </TouchableOpacity> | ||||
|         </View> | ||||
|  | @ -254,7 +254,7 @@ function ProvidedHandleForm({ | |||
|         <TextInput | ||||
|           testID="setHandleInput" | ||||
|           style={[pal.text, styles.textInput]} | ||||
|           placeholder="e.g. alice" | ||||
|           placeholder={_(msg`e.g. alice`)} | ||||
|           placeholderTextColor={pal.colors.textLight} | ||||
|           autoCapitalize="none" | ||||
|           keyboardAppearance={theme.colorScheme} | ||||
|  | @ -277,8 +277,8 @@ function ProvidedHandleForm({ | |||
|       <TouchableOpacity | ||||
|         onPress={onToggleCustom} | ||||
|         accessibilityRole="button" | ||||
|         accessibilityHint="Hosting provider" | ||||
|         accessibilityLabel={_(msg`Opens modal for using custom domain`)}> | ||||
|         accessibilityLabel={_(msg`Hosting provider`)} | ||||
|         accessibilityHint={_(msg`Opens modal for using custom domain`)}> | ||||
|         <Text type="md-medium" style={[pal.link, s.pl10, s.pt5]}> | ||||
|           <Trans>I have my own domain</Trans> | ||||
|         </Text> | ||||
|  | @ -324,8 +324,8 @@ function CustomHandleForm({ | |||
|     Clipboard.setString( | ||||
|       isDNSForm ? `did=${currentAccount.did}` : currentAccount.did, | ||||
|     ) | ||||
|     Toast.show('Copied to clipboard') | ||||
|   }, [currentAccount, isDNSForm]) | ||||
|     Toast.show(_(msg`Copied to clipboard`)) | ||||
|   }, [currentAccount, isDNSForm, _]) | ||||
|   const onChangeHandle = React.useCallback( | ||||
|     (v: string) => { | ||||
|       setHandle(v) | ||||
|  | @ -378,7 +378,7 @@ function CustomHandleForm({ | |||
|         <TextInput | ||||
|           testID="setHandleInput" | ||||
|           style={[pal.text, styles.textInput]} | ||||
|           placeholder="e.g. alice.com" | ||||
|           placeholder={_(msg`e.g. alice.com`)} | ||||
|           placeholderTextColor={pal.colors.textLight} | ||||
|           autoCapitalize="none" | ||||
|           keyboardAppearance={theme.colorScheme} | ||||
|  | @ -387,7 +387,7 @@ function CustomHandleForm({ | |||
|           editable={!isProcessing} | ||||
|           accessibilityLabelledBy="customDomain" | ||||
|           accessibilityLabel={_(msg`Custom domain`)} | ||||
|           accessibilityHint="Input your preferred hosting provider" | ||||
|           accessibilityHint={_(msg`Input your preferred hosting provider`)} | ||||
|         /> | ||||
|       </View> | ||||
|       <View style={styles.spacer} /> | ||||
|  | @ -395,18 +395,18 @@ function CustomHandleForm({ | |||
|       <View style={[styles.selectableBtns]}> | ||||
|         <SelectableBtn | ||||
|           selected={isDNSForm} | ||||
|           label="DNS Panel" | ||||
|           label={_(msg`DNS Panel`)} | ||||
|           left | ||||
|           onSelect={() => setDNSForm(true)} | ||||
|           accessibilityHint="Use the DNS panel" | ||||
|           accessibilityHint={_(msg`Use the DNS panel`)} | ||||
|           style={s.flex1} | ||||
|         /> | ||||
|         <SelectableBtn | ||||
|           selected={!isDNSForm} | ||||
|           label="No DNS Panel" | ||||
|           label={_(msg`No DNS Panel`)} | ||||
|           right | ||||
|           onSelect={() => setDNSForm(false)} | ||||
|           accessibilityHint="Use a file on your server" | ||||
|           accessibilityHint={_(msg`Use a file on your server`)} | ||||
|           style={s.flex1} | ||||
|         /> | ||||
|       </View> | ||||
|  | @ -418,7 +418,7 @@ function CustomHandleForm({ | |||
|           </Text> | ||||
|           <View style={[styles.dnsTable, pal.btn]}> | ||||
|             <Text type="md-medium" style={[styles.dnsLabel, pal.text]}> | ||||
|               Host: | ||||
|               <Trans>Host:</Trans> | ||||
|             </Text> | ||||
|             <View style={[styles.dnsValue]}> | ||||
|               <Text type="mono" style={[styles.monoText, pal.text]}> | ||||
|  | @ -426,7 +426,7 @@ function CustomHandleForm({ | |||
|               </Text> | ||||
|             </View> | ||||
|             <Text type="md-medium" style={[styles.dnsLabel, pal.text]}> | ||||
|               Type: | ||||
|               <Trans>Type:</Trans> | ||||
|             </Text> | ||||
|             <View style={[styles.dnsValue]}> | ||||
|               <Text type="mono" style={[styles.monoText, pal.text]}> | ||||
|  | @ -434,7 +434,7 @@ function CustomHandleForm({ | |||
|               </Text> | ||||
|             </View> | ||||
|             <Text type="md-medium" style={[styles.dnsLabel, pal.text]}> | ||||
|               Value: | ||||
|               <Trans>Value:</Trans> | ||||
|             </Text> | ||||
|             <View style={[styles.dnsValue]}> | ||||
|               <Text type="mono" style={[styles.monoText, pal.text]}> | ||||
|  | @ -443,7 +443,7 @@ function CustomHandleForm({ | |||
|             </View> | ||||
|           </View> | ||||
|           <Text type="md" style={[pal.text, s.pt20, s.pl5]}> | ||||
|             This should create a domain record at:{' '} | ||||
|             <Trans>This should create a domain record at:</Trans> | ||||
|           </Text> | ||||
|           <Text type="mono" style={[styles.monoText, pal.text, s.pt5, s.pl5]}> | ||||
|             _atproto.{handle} | ||||
|  | @ -463,7 +463,7 @@ function CustomHandleForm({ | |||
|           </View> | ||||
|           <View style={styles.spacer} /> | ||||
|           <Text type="md" style={[pal.text, s.pb5, s.pl5]}> | ||||
|             That contains the following: | ||||
|             <Trans>That contains the following:</Trans> | ||||
|           </Text> | ||||
|           <View style={[styles.valueContainer, pal.btn]}> | ||||
|             <View style={[styles.dnsValue]}> | ||||
|  | @ -478,7 +478,9 @@ function CustomHandleForm({ | |||
|       <View style={styles.spacer} /> | ||||
|       <Button type="default" style={[s.p20, s.mb10]} onPress={onPressCopy}> | ||||
|         <Text type="xl" style={[pal.link, s.textCenter]}> | ||||
|           Copy {isDNSForm ? 'Domain Value' : 'File Contents'} | ||||
|           <Trans> | ||||
|             Copy {isDNSForm ? _(msg`Domain Value`) : _(msg`File Contents`)} | ||||
|           </Trans> | ||||
|         </Text> | ||||
|       </Button> | ||||
|       {canSave === true && ( | ||||
|  | @ -504,8 +506,8 @@ function CustomHandleForm({ | |||
|         ) : ( | ||||
|           <Text type="xl-medium" style={[s.white, s.textCenter]}> | ||||
|             {canSave | ||||
|               ? `Update to ${handle}` | ||||
|               : `Verify ${isDNSForm ? 'DNS Record' : 'Text File'}`} | ||||
|               ? _(msg`Update to ${handle}`) | ||||
|               : _(msg`Verify ${isDNSForm ? 'DNS Record' : 'Text File'}`)} | ||||
|           </Text> | ||||
|         )} | ||||
|       </Button> | ||||
|  | @ -513,9 +515,9 @@ function CustomHandleForm({ | |||
|       <TouchableOpacity | ||||
|         onPress={onToggleCustom} | ||||
|         accessibilityLabel={_(msg`Use default provider`)} | ||||
|         accessibilityHint="Use bsky.social as hosting provider"> | ||||
|         accessibilityHint={_(msg`Use bsky.social as hosting provider`)}> | ||||
|         <Text type="md-medium" style={[pal.link, s.pl10, s.pt5]}> | ||||
|           Nevermind, create a handle for me | ||||
|           <Trans>Nevermind, create a handle for me</Trans> | ||||
|         </Text> | ||||
|       </TouchableOpacity> | ||||
|     </> | ||||
|  |  | |||
|  | @ -180,7 +180,7 @@ export function Component() { | |||
|                 <TextInput | ||||
|                   testID="codeInput" | ||||
|                   style={[pal.text, styles.textInput]} | ||||
|                   placeholder="Reset code" | ||||
|                   placeholder={_(msg`Reset code`)} | ||||
|                   placeholderTextColor={pal.colors.textLight} | ||||
|                   value={resetCode} | ||||
|                   onChangeText={setResetCode} | ||||
|  | @ -207,7 +207,7 @@ export function Component() { | |||
|                 <TextInput | ||||
|                   testID="codeInput" | ||||
|                   style={[pal.text, styles.textInput]} | ||||
|                   placeholder="New password" | ||||
|                   placeholder={_(msg`New password`)} | ||||
|                   placeholderTextColor={pal.colors.textLight} | ||||
|                   onChangeText={setNewPassword} | ||||
|                   secureTextEntry | ||||
|  |  | |||
|  | @ -173,7 +173,7 @@ export function Component({}: {}) { | |||
|             </Text> | ||||
|             <TextInput | ||||
|               style={[styles.textInput, pal.borderDark, pal.text, styles.mb20]} | ||||
|               placeholder="Confirmation code" | ||||
|               placeholder={_(msg`Confirmation code`)} | ||||
|               placeholderTextColor={pal.textLight.color} | ||||
|               keyboardAppearance={theme.colorScheme} | ||||
|               value={confirmCode} | ||||
|  | @ -192,7 +192,7 @@ export function Component({}: {}) { | |||
|             </Text> | ||||
|             <TextInput | ||||
|               style={[styles.textInput, pal.borderDark, pal.text]} | ||||
|               placeholder="Password" | ||||
|               placeholder={_(msg`Password`)} | ||||
|               placeholderTextColor={pal.textLight.color} | ||||
|               keyboardAppearance={theme.colorScheme} | ||||
|               secureTextEntry | ||||
|  | @ -228,7 +228,7 @@ export function Component({}: {}) { | |||
|                   onPress={onCancel} | ||||
|                   accessibilityRole="button" | ||||
|                   accessibilityLabel={_(msg`Cancel account deletion`)} | ||||
|                   accessibilityHint="Exits account deletion process" | ||||
|                   accessibilityHint={_(msg`Exits account deletion process`)} | ||||
|                   onAccessibilityEscape={onCancel}> | ||||
|                   <Text type="button-lg" style={pal.textLight}> | ||||
|                     <Trans context="action">Cancel</Trans> | ||||
|  |  | |||
|  | @ -77,7 +77,7 @@ export function Component({href}: {href: string}) { | |||
|           }} | ||||
|           accessibilityLabel={_(msg`Cancel`)} | ||||
|           accessibilityHint="" | ||||
|           label="Cancel" | ||||
|           label={_(msg`Cancel`)} | ||||
|           labelContainerStyle={{justifyContent: 'center', padding: 8}} | ||||
|           labelStyle={[s.f18]} | ||||
|         /> | ||||
|  |  | |||
|  | @ -74,7 +74,7 @@ export function Component({text, href}: {text: string; href: string}) { | |||
|             onPress={onPressVisit} | ||||
|             accessibilityLabel={_(msg`Visit Site`)} | ||||
|             accessibilityHint="" | ||||
|             label="Visit Site" | ||||
|             label={_(msg`Visit Site`)} | ||||
|             labelContainerStyle={{justifyContent: 'center', padding: 4}} | ||||
|             labelStyle={[s.f18]} | ||||
|           /> | ||||
|  | @ -86,7 +86,7 @@ export function Component({text, href}: {text: string; href: string}) { | |||
|             }} | ||||
|             accessibilityLabel={_(msg`Cancel`)} | ||||
|             accessibilityHint="" | ||||
|             label="Cancel" | ||||
|             label={_(msg`Cancel`)} | ||||
|             labelContainerStyle={{justifyContent: 'center', padding: 4}} | ||||
|             labelStyle={[s.f18]} | ||||
|           /> | ||||
|  |  | |||
|  | @ -115,7 +115,7 @@ export function Component({ | |||
|           closeModal() | ||||
|         }}> | ||||
|         <Text type="button-lg" style={[pal.textLight, s.textCenter, s.white]}> | ||||
|           Okay | ||||
|           <Trans>Okay</Trans> | ||||
|         </Text> | ||||
|       </Button> | ||||
|     </View> | ||||
|  |  | |||
|  | @ -149,7 +149,7 @@ export function Component({showReminder}: {showReminder?: boolean}) { | |||
|               onPress={onEmailIncorrect} | ||||
|               style={styles.changeEmailLink}> | ||||
|               <Text type="lg" style={pal.link}> | ||||
|                 Change | ||||
|                 <Trans>Change</Trans> | ||||
|               </Text> | ||||
|             </Pressable> | ||||
|           </> | ||||
|  |  | |||
|  | @ -100,7 +100,7 @@ export function Component({ | |||
|           onPress={doSetAs(AspectRatio.Wide)} | ||||
|           accessibilityRole="button" | ||||
|           accessibilityLabel={_(msg`Wide`)} | ||||
|           accessibilityHint="Sets image aspect ratio to wide"> | ||||
|           accessibilityHint={_(msg`Sets image aspect ratio to wide`)}> | ||||
|           <RectWideIcon | ||||
|             size={24} | ||||
|             style={as === AspectRatio.Wide ? s.blue3 : pal.text} | ||||
|  | @ -110,7 +110,7 @@ export function Component({ | |||
|           onPress={doSetAs(AspectRatio.Tall)} | ||||
|           accessibilityRole="button" | ||||
|           accessibilityLabel={_(msg`Tall`)} | ||||
|           accessibilityHint="Sets image aspect ratio to tall"> | ||||
|           accessibilityHint={_(msg`Sets image aspect ratio to tall`)}> | ||||
|           <RectTallIcon | ||||
|             size={24} | ||||
|             style={as === AspectRatio.Tall ? s.blue3 : pal.text} | ||||
|  | @ -120,7 +120,7 @@ export function Component({ | |||
|           onPress={doSetAs(AspectRatio.Square)} | ||||
|           accessibilityRole="button" | ||||
|           accessibilityLabel={_(msg`Square`)} | ||||
|           accessibilityHint="Sets image aspect ratio to square"> | ||||
|           accessibilityHint={_(msg`Sets image aspect ratio to square`)}> | ||||
|           <SquareIcon | ||||
|             size={24} | ||||
|             style={as === AspectRatio.Square ? s.blue3 : pal.text} | ||||
|  | @ -132,9 +132,9 @@ export function Component({ | |||
|           onPress={onPressCancel} | ||||
|           accessibilityRole="button" | ||||
|           accessibilityLabel={_(msg`Cancel image crop`)} | ||||
|           accessibilityHint="Exits image cropping process"> | ||||
|           accessibilityHint={_(msg`Exits image cropping process`)}> | ||||
|           <Text type="xl" style={pal.link}> | ||||
|             Cancel | ||||
|             <Trans>Cancel</Trans> | ||||
|           </Text> | ||||
|         </TouchableOpacity> | ||||
|         <View style={s.flex1} /> | ||||
|  | @ -142,7 +142,7 @@ export function Component({ | |||
|           onPress={onPressDone} | ||||
|           accessibilityRole="button" | ||||
|           accessibilityLabel={_(msg`Save image crop`)} | ||||
|           accessibilityHint="Saves image crop settings"> | ||||
|           accessibilityHint={_(msg`Saves image crop settings`)}> | ||||
|           <LinearGradient | ||||
|             colors={[gradients.blueLight.start, gradients.blueLight.end]} | ||||
|             start={{x: 0, y: 0}} | ||||
|  |  | |||
|  | @ -39,7 +39,7 @@ export function InputIssueDetails({ | |||
|         onPress={goBack} | ||||
|         accessibilityRole="button" | ||||
|         accessibilityLabel={_(msg`Add details`)} | ||||
|         accessibilityHint="Add more details to your report"> | ||||
|         accessibilityHint={_(msg`Add more details to your report`)}> | ||||
|         <FontAwesomeIcon size={18} icon="angle-left" style={[pal.link]} /> | ||||
|         <Text style={[pal.text, s.f18, pal.link]}> | ||||
|           {' '} | ||||
|  | @ -49,8 +49,8 @@ export function InputIssueDetails({ | |||
|       <View style={[pal.btn, styles.detailsInputContainer]}> | ||||
|         <TextInput | ||||
|           accessibilityLabel={_(msg`Text input field`)} | ||||
|           accessibilityHint="Enter a reason for reporting this post." | ||||
|           placeholder="Enter a reason or any other details here." | ||||
|           accessibilityHint={_(msg`Enter a reason for reporting this post.`)} | ||||
|           placeholder={_(msg`Enter a reason or any other details here.`)} | ||||
|           placeholderTextColor={pal.textLight.color} | ||||
|           value={details} | ||||
|           onChangeText={setDetails} | ||||
|  |  | |||
|  | @ -41,6 +41,7 @@ type ReportComponentProps = | |||
| export function Component(content: ReportComponentProps) { | ||||
|   const {closeModal} = useModalControls() | ||||
|   const pal = usePalette('default') | ||||
|   const {_} = useLingui() | ||||
|   const {isMobile} = useWebMediaQueries() | ||||
|   const [isProcessing, setIsProcessing] = useState(false) | ||||
|   const [showDetailsInput, setShowDetailsInput] = useState(false) | ||||
|  | @ -77,7 +78,9 @@ export function Component(content: ReportComponentProps) { | |||
|         }, | ||||
|         reason: details, | ||||
|       }) | ||||
|       Toast.show("Thank you for your report! We'll look into it promptly.") | ||||
|       Toast.show( | ||||
|         _(msg`Thank you for your report! We'll look into it promptly.`), | ||||
|       ) | ||||
| 
 | ||||
|       closeModal() | ||||
|       return | ||||
|  | @ -189,7 +192,7 @@ const SelectIssue = ({ | |||
|             onPress={goToDetails} | ||||
|             accessibilityRole="button" | ||||
|             accessibilityLabel={_(msg`Add details`)} | ||||
|             accessibilityHint="Add more details to your report"> | ||||
|             accessibilityHint={_(msg`Add more details to your report`)}> | ||||
|             <Text style={[s.f18, pal.link]}> | ||||
|               <Trans>Add details to report</Trans> | ||||
|             </Text> | ||||
|  |  | |||
|  | @ -296,7 +296,7 @@ let PostThreadItemLoaded = ({ | |||
|                       color={pal.colors.textLight} | ||||
|                     /> | ||||
|                     <Text type="sm-medium" style={pal.textLight}> | ||||
|                       Muted | ||||
|                       <Trans>Muted</Trans> | ||||
|                     </Text> | ||||
|                   </View> | ||||
|                 )} | ||||
|  | @ -578,7 +578,7 @@ let PostThreadItemLoaded = ({ | |||
|                 title={itemTitle} | ||||
|                 noFeedback> | ||||
|                 <Text type="sm-medium" style={pal.textLight}> | ||||
|                   More | ||||
|                   <Trans>More</Trans> | ||||
|                 </Text> | ||||
|                 <FontAwesomeIcon | ||||
|                   icon="angle-right" | ||||
|  |  | |||
|  | @ -21,7 +21,8 @@ import {useModerationOpts} from '#/state/queries/preferences' | |||
| import {useSuggestedFollowsByActorQuery} from '#/state/queries/suggested-follows' | ||||
| import {useProfileShadow} from '#/state/cache/profile-shadow' | ||||
| import {useProfileFollowMutationQueue} from '#/state/queries/profile' | ||||
| import {Trans} from '@lingui/macro' | ||||
| import {useLingui} from '@lingui/react' | ||||
| import {Trans, msg} from '@lingui/macro' | ||||
| 
 | ||||
| const OUTER_PADDING = 10 | ||||
| const INNER_PADDING = 14 | ||||
|  | @ -168,6 +169,7 @@ function SuggestedFollow({ | |||
| }) { | ||||
|   const {track} = useAnalytics() | ||||
|   const pal = usePalette('default') | ||||
|   const {_} = useLingui() | ||||
|   const moderationOpts = useModerationOpts() | ||||
|   const profile = useProfileShadow(profileUnshadowed) | ||||
|   const [queueFollow, queueUnfollow] = useProfileFollowMutationQueue(profile) | ||||
|  | @ -178,20 +180,20 @@ function SuggestedFollow({ | |||
|       await queueFollow() | ||||
|     } catch (e: any) { | ||||
|       if (e?.name !== 'AbortError') { | ||||
|         Toast.show('An issue occurred, please try again.') | ||||
|         Toast.show(_(msg`An issue occurred, please try again.`)) | ||||
|       } | ||||
|     } | ||||
|   }, [queueFollow, track]) | ||||
|   }, [queueFollow, track, _]) | ||||
| 
 | ||||
|   const onPressUnfollow = React.useCallback(async () => { | ||||
|     try { | ||||
|       await queueUnfollow() | ||||
|     } catch (e: any) { | ||||
|       if (e?.name !== 'AbortError') { | ||||
|         Toast.show('An issue occurred, please try again.') | ||||
|         Toast.show(_(msg`An issue occurred, please try again.`)) | ||||
|       } | ||||
|     } | ||||
|   }, [queueUnfollow]) | ||||
|   }, [queueUnfollow, _]) | ||||
| 
 | ||||
|   if (!moderationOpts) { | ||||
|     return null | ||||
|  | @ -236,7 +238,7 @@ function SuggestedFollow({ | |||
|         </View> | ||||
| 
 | ||||
|         <Button | ||||
|           label={following ? 'Unfollow' : 'Follow'} | ||||
|           label={following ? _(msg`Unfollow`) : _(msg`Follow`)} | ||||
|           type="inverted" | ||||
|           labelStyle={{textAlign: 'center'}} | ||||
|           onPress={following ? onPressUnfollow : onPressFollow} | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue