Some me model cleanup (#1928)
* Replace me model in post dropdown btn * Replace delete account logic * Replace me model in bottom bar web * Replace me model in bottom bar * Replace me model in reply prompt * Better fallback * Fix reference * Fix bad ref in bottom bar
This commit is contained in:
		
							parent
							
								
									a652b52b88
								
							
						
					
					
						commit
						310a7eaca7
					
				
					 5 changed files with 41 additions and 22 deletions
				
			
		|  | @ -3,13 +3,15 @@ import {StyleSheet, TouchableOpacity} from 'react-native' | |||
| import {UserAvatar} from '../util/UserAvatar' | ||||
| import {Text} from '../util/text/Text' | ||||
| import {usePalette} from 'lib/hooks/usePalette' | ||||
| import {useStores} from 'state/index' | ||||
| import {useWebMediaQueries} from 'lib/hooks/useWebMediaQueries' | ||||
| import {Trans, msg} from '@lingui/macro' | ||||
| import {useLingui} from '@lingui/react' | ||||
| import {useSession} from '#/state/session' | ||||
| import {useProfileQuery} from '#/state/queries/profile' | ||||
| 
 | ||||
| export function ComposePrompt({onPressCompose}: {onPressCompose: () => void}) { | ||||
|   const store = useStores() | ||||
|   const {currentAccount} = useSession() | ||||
|   const {data: profile} = useProfileQuery({did: currentAccount?.did}) | ||||
|   const pal = usePalette('default') | ||||
|   const {_} = useLingui() | ||||
|   const {isDesktop} = useWebMediaQueries() | ||||
|  | @ -21,7 +23,7 @@ export function ComposePrompt({onPressCompose}: {onPressCompose: () => void}) { | |||
|       accessibilityRole="button" | ||||
|       accessibilityLabel={_(msg`Compose reply`)} | ||||
|       accessibilityHint="Opens composer"> | ||||
|       <UserAvatar avatar={store.me.avatar} size={38} /> | ||||
|       <UserAvatar avatar={profile?.avatar} size={38} /> | ||||
|       <Text | ||||
|         type="xl" | ||||
|         style={[ | ||||
|  |  | |||
|  | @ -9,7 +9,6 @@ import {TextInput} from './util' | |||
| import LinearGradient from 'react-native-linear-gradient' | ||||
| import * as Toast from '../util/Toast' | ||||
| import {Text} from '../util/text/Text' | ||||
| import {useStores} from 'state/index' | ||||
| import {s, colors, gradients} from 'lib/styles' | ||||
| import {usePalette} from 'lib/hooks/usePalette' | ||||
| import {useTheme} from 'lib/ThemeContext' | ||||
|  | @ -20,13 +19,15 @@ import {resetToTab} from '../../../Navigation' | |||
| import {Trans, msg} from '@lingui/macro' | ||||
| import {useLingui} from '@lingui/react' | ||||
| import {useModalControls} from '#/state/modals' | ||||
| import {useSession, useSessionApi} from '#/state/session' | ||||
| 
 | ||||
| export const snapPoints = ['60%'] | ||||
| 
 | ||||
| export function Component({}: {}) { | ||||
|   const pal = usePalette('default') | ||||
|   const theme = useTheme() | ||||
|   const store = useStores() | ||||
|   const {agent, currentAccount} = useSession() | ||||
|   const {clearCurrentAccount, removeAccount} = useSessionApi() | ||||
|   const {_} = useLingui() | ||||
|   const {closeModal} = useModalControls() | ||||
|   const {isMobile} = useWebMediaQueries() | ||||
|  | @ -39,7 +40,7 @@ export function Component({}: {}) { | |||
|     setError('') | ||||
|     setIsProcessing(true) | ||||
|     try { | ||||
|       await store.agent.com.atproto.server.requestAccountDelete() | ||||
|       await agent.com.atproto.server.requestAccountDelete() | ||||
|       setIsEmailSent(true) | ||||
|     } catch (e: any) { | ||||
|       setError(cleanError(e)) | ||||
|  | @ -47,19 +48,24 @@ export function Component({}: {}) { | |||
|     setIsProcessing(false) | ||||
|   } | ||||
|   const onPressConfirmDelete = async () => { | ||||
|     if (!currentAccount?.did) { | ||||
|       throw new Error(`DeleteAccount modal: currentAccount.did is undefined`) | ||||
|     } | ||||
| 
 | ||||
|     setError('') | ||||
|     setIsProcessing(true) | ||||
|     const token = confirmCode.replace(/\s/g, '') | ||||
| 
 | ||||
|     try { | ||||
|       await store.agent.com.atproto.server.deleteAccount({ | ||||
|         did: store.me.did, | ||||
|       await agent.com.atproto.server.deleteAccount({ | ||||
|         did: currentAccount.did, | ||||
|         password, | ||||
|         token, | ||||
|       }) | ||||
|       Toast.show('Your account has been deleted') | ||||
|       resetToTab('HomeTab') | ||||
|       store.session.clear() | ||||
|       removeAccount(currentAccount) | ||||
|       clearCurrentAccount() | ||||
|       closeModal() | ||||
|     } catch (e: any) { | ||||
|       setError(cleanError(e)) | ||||
|  | @ -88,7 +94,7 @@ export function Component({}: {}) { | |||
|                 pal.text, | ||||
|                 s.bold, | ||||
|               ]}> | ||||
|               {store.me.handle} | ||||
|               {currentAccount?.handle} | ||||
|             </Text> | ||||
|             <Text type="title-xl" style={[pal.text, s.bold]}> | ||||
|               {'"'} | ||||
|  |  | |||
|  | @ -15,12 +15,12 @@ import {EventStopper} from '../EventStopper' | |||
| import {useModalControls} from '#/state/modals' | ||||
| import {makeProfileLink} from '#/lib/routes/links' | ||||
| import {getTranslatorLink} from '#/locale/helpers' | ||||
| import {useStores} from '#/state' | ||||
| import {usePostDeleteMutation} from '#/state/queries/post' | ||||
| import {useMutedThreads, useToggleThreadMute} from '#/state/muted-threads' | ||||
| import {useLanguagePrefs} from '#/state/preferences' | ||||
| import {logger} from '#/logger' | ||||
| import {Shadow} from '#/state/cache/types' | ||||
| import {useSession} from '#/state/session' | ||||
| 
 | ||||
| export function PostDropdownBtn({ | ||||
|   testID, | ||||
|  | @ -33,7 +33,7 @@ export function PostDropdownBtn({ | |||
|   record: AppBskyFeedPost.Record | ||||
|   style?: StyleProp<ViewStyle> | ||||
| }) { | ||||
|   const store = useStores() | ||||
|   const {currentAccount} = useSession() | ||||
|   const theme = useTheme() | ||||
|   const defaultCtrlColor = theme.palette.default.postCtrl | ||||
|   const {openModal} = useModalControls() | ||||
|  | @ -44,7 +44,7 @@ export function PostDropdownBtn({ | |||
| 
 | ||||
|   const rootUri = record.reply?.root?.uri || post.uri | ||||
|   const isThreadMuted = mutedThreads.includes(rootUri) | ||||
|   const isAuthor = post.author.did === store.me.did | ||||
|   const isAuthor = post.author.did === currentAccount?.did | ||||
|   const href = React.useMemo(() => { | ||||
|     const urip = new AtUri(post.uri) | ||||
|     return makeProfileLink(post.author, 'post', urip.rkey) | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue