about summary refs log tree commit diff
path: root/src/components/hooks
diff options
context:
space:
mode:
authorEric Bailey <git@esb.lol>2024-04-25 16:29:05 -0500
committerGitHub <noreply@github.com>2024-04-25 22:29:05 +0100
commit45d354cd0c76563de6d3d1146bebb750e0f6d4a0 (patch)
tree0939d1d6d91a4f812b1abeb005c6347b39692086 /src/components/hooks
parentd8c8e1e854654dbcf9585d0b3bd8c87d77df2e0f (diff)
downloadvoidsky-45d354cd0c76563de6d3d1146bebb750e0f6d4a0.tar.zst
[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>
Diffstat (limited to 'src/components/hooks')
-rw-r--r--src/components/hooks/useRichText.ts5
1 files changed, 3 insertions, 2 deletions
diff --git a/src/components/hooks/useRichText.ts b/src/components/hooks/useRichText.ts
index e363ae5a9..4329638ea 100644
--- a/src/components/hooks/useRichText.ts
+++ b/src/components/hooks/useRichText.ts
@@ -1,12 +1,13 @@
 import React from 'react'
 import {RichText as RichTextAPI} from '@atproto/api'
 
-import {getAgent} from '#/state/session'
+import {useAgent} from '#/state/session'
 
 export function useRichText(text: string): [RichTextAPI, boolean] {
   const [prevText, setPrevText] = React.useState(text)
   const [rawRT, setRawRT] = React.useState(() => new RichTextAPI({text}))
   const [resolvedRT, setResolvedRT] = React.useState<RichTextAPI | null>(null)
+  const {getAgent} = useAgent()
   if (text !== prevText) {
     setPrevText(text)
     setRawRT(new RichTextAPI({text}))
@@ -27,7 +28,7 @@ export function useRichText(text: string): [RichTextAPI, boolean] {
     return () => {
       ignore = true
     }
-  }, [text])
+  }, [text, getAgent])
   const isResolving = resolvedRT === null
   return [resolvedRT ?? rawRT, isResolving]
 }