[Session] Add useAgent hook and replace (#3706)
				
					
				
			* Hook it up * Memoize getAgent method * Use one shared reference --------- Co-authored-by: Dan Abramov <dan.abramov@gmail.com>
This commit is contained in:
		
							parent
							
								
									d8c8e1e854
								
							
						
					
					
						commit
						45d354cd0c
					
				
					 53 changed files with 231 additions and 114 deletions
				
			
		|  | @ -32,7 +32,7 @@ import { | |||
| import {useProfileQuery} from '#/state/queries/profile' | ||||
| import {Gif} from '#/state/queries/tenor' | ||||
| import {ThreadgateSetting} from '#/state/queries/threadgate' | ||||
| import {getAgent, useSession} from '#/state/session' | ||||
| import {useAgent, useSession} from '#/state/session' | ||||
| import {useComposerControls} from '#/state/shell/composer' | ||||
| import {useAnalytics} from 'lib/analytics/analytics' | ||||
| import * as apilib from 'lib/api/index' | ||||
|  | @ -83,6 +83,7 @@ export const ComposePost = observer(function ComposePost({ | |||
|   imageUris: initImageUris, | ||||
| }: Props) { | ||||
|   const {currentAccount} = useSession() | ||||
|   const {getAgent} = useAgent() | ||||
|   const {data: currentProfile} = useProfileQuery({did: currentAccount!.did}) | ||||
|   const {isModalActive} = useModals() | ||||
|   const {closeComposer} = useComposerControls() | ||||
|  |  | |||
|  | @ -1,12 +1,14 @@ | |||
| import {useState, useEffect} from 'react' | ||||
| import {useEffect, useState} from 'react' | ||||
| 
 | ||||
| import {useAgent} from '#/state/session' | ||||
| import * as apilib from 'lib/api/index' | ||||
| import {getLinkMeta} from 'lib/link-meta/link-meta' | ||||
| import {ComposerOpts} from 'state/shell/composer' | ||||
| import {getAgent} from '#/state/session' | ||||
| 
 | ||||
| export function useExternalLinkFetch({}: { | ||||
|   setQuote: (opts: ComposerOpts['quote']) => void | ||||
| }) { | ||||
|   const {getAgent} = useAgent() | ||||
|   const [extLink, setExtLink] = useState<apilib.ExternalEmbedDraft | undefined>( | ||||
|     undefined, | ||||
|   ) | ||||
|  | @ -39,7 +41,7 @@ export function useExternalLinkFetch({}: { | |||
|       }) | ||||
|     } | ||||
|     return cleanup | ||||
|   }, [extLink]) | ||||
|   }, [extLink, getAgent]) | ||||
| 
 | ||||
|   return {extLink, setExtLink} | ||||
| } | ||||
|  |  | |||
|  | @ -1,24 +1,25 @@ | |||
| import {useState, useEffect} from 'react' | ||||
| import {ImageModel} from 'state/models/media/image' | ||||
| import {useEffect, useState} from 'react' | ||||
| 
 | ||||
| import {logger} from '#/logger' | ||||
| import {useFetchDid} from '#/state/queries/handle' | ||||
| import {useGetPost} from '#/state/queries/post' | ||||
| import {useAgent} from '#/state/session' | ||||
| import * as apilib from 'lib/api/index' | ||||
| import {getLinkMeta} from 'lib/link-meta/link-meta' | ||||
| import {POST_IMG_MAX} from 'lib/constants' | ||||
| import { | ||||
|   getPostAsQuote, | ||||
|   getFeedAsEmbed, | ||||
|   getListAsEmbed, | ||||
|   getPostAsQuote, | ||||
| } from 'lib/link-meta/bsky' | ||||
| import {getLinkMeta} from 'lib/link-meta/link-meta' | ||||
| import {downloadAndResize} from 'lib/media/manip' | ||||
| import { | ||||
|   isBskyPostUrl, | ||||
|   isBskyCustomFeedUrl, | ||||
|   isBskyListUrl, | ||||
|   isBskyPostUrl, | ||||
| } from 'lib/strings/url-helpers' | ||||
| import {ImageModel} from 'state/models/media/image' | ||||
| import {ComposerOpts} from 'state/shell/composer' | ||||
| import {POST_IMG_MAX} from 'lib/constants' | ||||
| import {logger} from '#/logger' | ||||
| import {getAgent} from '#/state/session' | ||||
| import {useGetPost} from '#/state/queries/post' | ||||
| import {useFetchDid} from '#/state/queries/handle' | ||||
| 
 | ||||
| export function useExternalLinkFetch({ | ||||
|   setQuote, | ||||
|  | @ -30,6 +31,7 @@ export function useExternalLinkFetch({ | |||
|   ) | ||||
|   const getPost = useGetPost() | ||||
|   const fetchDid = useFetchDid() | ||||
|   const {getAgent} = useAgent() | ||||
| 
 | ||||
|   useEffect(() => { | ||||
|     let aborted = false | ||||
|  | @ -135,7 +137,7 @@ export function useExternalLinkFetch({ | |||
|       }) | ||||
|     } | ||||
|     return cleanup | ||||
|   }, [extLink, setQuote, getPost, fetchDid]) | ||||
|   }, [extLink, setQuote, getPost, fetchDid, getAgent]) | ||||
| 
 | ||||
|   return {extLink, setExtLink} | ||||
| } | ||||
|  |  | |||
|  | @ -1,19 +1,20 @@ | |||
| import React, {useState} from 'react' | ||||
| import {ActivityIndicator, SafeAreaView, StyleSheet, View} from 'react-native' | ||||
| import {ScrollView, TextInput} from './util' | ||||
| import {Text} from '../util/text/Text' | ||||
| import {Button} from '../util/forms/Button' | ||||
| import {ErrorMessage} from '../util/error/ErrorMessage' | ||||
| import * as Toast from '../util/Toast' | ||||
| import {s, colors} from 'lib/styles' | ||||
| import {msg, Trans} from '@lingui/macro' | ||||
| import {useLingui} from '@lingui/react' | ||||
| 
 | ||||
| import {useModalControls} from '#/state/modals' | ||||
| import {useAgent, useSession, useSessionApi} from '#/state/session' | ||||
| import {usePalette} from 'lib/hooks/usePalette' | ||||
| import {isWeb} from 'platform/detection' | ||||
| import {useWebMediaQueries} from 'lib/hooks/useWebMediaQueries' | ||||
| import {cleanError} from 'lib/strings/errors' | ||||
| import {Trans, msg} from '@lingui/macro' | ||||
| import {useLingui} from '@lingui/react' | ||||
| import {useModalControls} from '#/state/modals' | ||||
| import {useSession, useSessionApi, getAgent} from '#/state/session' | ||||
| import {colors, s} from 'lib/styles' | ||||
| import {isWeb} from 'platform/detection' | ||||
| import {ErrorMessage} from '../util/error/ErrorMessage' | ||||
| import {Button} from '../util/forms/Button' | ||||
| import {Text} from '../util/text/Text' | ||||
| import * as Toast from '../util/Toast' | ||||
| import {ScrollView, TextInput} from './util' | ||||
| 
 | ||||
| enum Stages { | ||||
|   InputEmail, | ||||
|  | @ -26,6 +27,7 @@ export const snapPoints = ['90%'] | |||
| export function Component() { | ||||
|   const pal = usePalette('default') | ||||
|   const {currentAccount} = useSession() | ||||
|   const {getAgent} = useAgent() | ||||
|   const {updateCurrentAccount} = useSessionApi() | ||||
|   const {_} = useLingui() | ||||
|   const [stage, setStage] = useState<Stages>(Stages.InputEmail) | ||||
|  |  | |||
|  | @ -16,8 +16,8 @@ import {useModalControls} from '#/state/modals' | |||
| import {useFetchDid, useUpdateHandleMutation} from '#/state/queries/handle' | ||||
| import {useServiceQuery} from '#/state/queries/service' | ||||
| import { | ||||
|   getAgent, | ||||
|   SessionAccount, | ||||
|   useAgent, | ||||
|   useSession, | ||||
|   useSessionApi, | ||||
| } from '#/state/session' | ||||
|  | @ -40,6 +40,7 @@ export type Props = {onChanged: () => void} | |||
| 
 | ||||
| export function Component(props: Props) { | ||||
|   const {currentAccount} = useSession() | ||||
|   const {getAgent} = useAgent() | ||||
|   const { | ||||
|     isLoading, | ||||
|     data: serviceInfo, | ||||
|  |  | |||
|  | @ -6,24 +6,25 @@ import { | |||
|   TouchableOpacity, | ||||
|   View, | ||||
| } from 'react-native' | ||||
| import {ScrollView} from './util' | ||||
| import {FontAwesomeIcon} from '@fortawesome/react-native-fontawesome' | ||||
| import {TextInput} from './util' | ||||
| import {Text} from '../util/text/Text' | ||||
| import {Button} from '../util/forms/Button' | ||||
| import {ErrorMessage} from '../util/error/ErrorMessage' | ||||
| import {s, colors} from 'lib/styles' | ||||
| import {msg, Trans} from '@lingui/macro' | ||||
| import {useLingui} from '@lingui/react' | ||||
| import * as EmailValidator from 'email-validator' | ||||
| 
 | ||||
| import {logger} from '#/logger' | ||||
| import {useModalControls} from '#/state/modals' | ||||
| import {useAgent, useSession} from '#/state/session' | ||||
| import {usePalette} from 'lib/hooks/usePalette' | ||||
| import {isAndroid, isWeb} from 'platform/detection' | ||||
| import {useWebMediaQueries} from 'lib/hooks/useWebMediaQueries' | ||||
| import {cleanError, isNetworkError} from 'lib/strings/errors' | ||||
| import {checkAndFormatResetCode} from 'lib/strings/password' | ||||
| import {Trans, msg} from '@lingui/macro' | ||||
| import {useLingui} from '@lingui/react' | ||||
| import {useModalControls} from '#/state/modals' | ||||
| import {useSession, getAgent} from '#/state/session' | ||||
| import * as EmailValidator from 'email-validator' | ||||
| import {logger} from '#/logger' | ||||
| import {colors, s} from 'lib/styles' | ||||
| import {isAndroid, isWeb} from 'platform/detection' | ||||
| import {ErrorMessage} from '../util/error/ErrorMessage' | ||||
| import {Button} from '../util/forms/Button' | ||||
| import {Text} from '../util/text/Text' | ||||
| import {ScrollView} from './util' | ||||
| import {TextInput} from './util' | ||||
| 
 | ||||
| enum Stages { | ||||
|   RequestCode, | ||||
|  | @ -36,6 +37,7 @@ export const snapPoints = isAndroid ? ['90%'] : ['45%'] | |||
| export function Component() { | ||||
|   const pal = usePalette('default') | ||||
|   const {currentAccount} = useSession() | ||||
|   const {getAgent} = useAgent() | ||||
|   const {_} = useLingui() | ||||
|   const [stage, setStage] = useState<Stages>(Stages.RequestCode) | ||||
|   const [isProcessing, setIsProcessing] = useState<boolean>(false) | ||||
|  |  | |||
|  | @ -25,7 +25,7 @@ import { | |||
|   useListCreateMutation, | ||||
|   useListMetadataMutation, | ||||
| } from '#/state/queries/list' | ||||
| import {getAgent} from '#/state/session' | ||||
| import {useAgent} from '#/state/session' | ||||
| import {useAnalytics} from 'lib/analytics/analytics' | ||||
| import {usePalette} from 'lib/hooks/usePalette' | ||||
| import {useWebMediaQueries} from 'lib/hooks/useWebMediaQueries' | ||||
|  | @ -62,6 +62,7 @@ export function Component({ | |||
|   const {_} = useLingui() | ||||
|   const listCreateMutation = useListCreateMutation() | ||||
|   const listMetadataMutation = useListMetadataMutation() | ||||
|   const {getAgent} = useAgent() | ||||
| 
 | ||||
|   const activePurpose = useMemo(() => { | ||||
|     if (list?.purpose) { | ||||
|  | @ -228,6 +229,7 @@ export function Component({ | |||
|     listMetadataMutation, | ||||
|     listCreateMutation, | ||||
|     _, | ||||
|     getAgent, | ||||
|   ]) | ||||
| 
 | ||||
|   return ( | ||||
|  |  | |||
|  | @ -11,7 +11,7 @@ import {msg, Trans} from '@lingui/macro' | |||
| import {useLingui} from '@lingui/react' | ||||
| 
 | ||||
| import {useModalControls} from '#/state/modals' | ||||
| import {getAgent, useSession, useSessionApi} from '#/state/session' | ||||
| import {useAgent, useSession, useSessionApi} from '#/state/session' | ||||
| import {usePalette} from 'lib/hooks/usePalette' | ||||
| import {useWebMediaQueries} from 'lib/hooks/useWebMediaQueries' | ||||
| import {cleanError} from 'lib/strings/errors' | ||||
|  | @ -30,6 +30,7 @@ export function Component({}: {}) { | |||
|   const pal = usePalette('default') | ||||
|   const theme = useTheme() | ||||
|   const {currentAccount} = useSession() | ||||
|   const {getAgent} = useAgent() | ||||
|   const {clearCurrentAccount, removeAccount} = useSessionApi() | ||||
|   const {_} = useLingui() | ||||
|   const {closeModal} = useModalControls() | ||||
|  |  | |||
|  | @ -13,7 +13,7 @@ import {useLingui} from '@lingui/react' | |||
| 
 | ||||
| import {logger} from '#/logger' | ||||
| import {useModalControls} from '#/state/modals' | ||||
| import {getAgent, useSession, useSessionApi} from '#/state/session' | ||||
| import {useAgent, useSession, useSessionApi} from '#/state/session' | ||||
| import {usePalette} from 'lib/hooks/usePalette' | ||||
| import {useWebMediaQueries} from 'lib/hooks/useWebMediaQueries' | ||||
| import {cleanError} from 'lib/strings/errors' | ||||
|  | @ -41,6 +41,7 @@ export function Component({ | |||
|   onSuccess?: () => void | ||||
| }) { | ||||
|   const pal = usePalette('default') | ||||
|   const {getAgent} = useAgent() | ||||
|   const {currentAccount} = useSession() | ||||
|   const {updateCurrentAccount} = useSessionApi() | ||||
|   const {_} = useLingui() | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue