TootBottomSheet: added cache
This commit is contained in:
		
							parent
							
								
									c0c5c8ee3b
								
							
						
					
					
						commit
						729eaa7901
					
				
					 2 changed files with 20 additions and 3 deletions
				
			
		|  | @ -43,6 +43,7 @@ import PullDownToRefresh from "./PullDownToRefresh"; | |||
| import { HeroSourceProvider, type HeroSource } from "../platform/anim"; | ||||
| import { useNavigate } from "@solidjs/router"; | ||||
| import { useSignedInProfiles } from "../masto/acct"; | ||||
| import { setCache as setTootBottomSheetCache } from "./TootBottomSheet"; | ||||
| 
 | ||||
| const TimelinePanel: Component<{ | ||||
|   client: mastodon.rest.Client; | ||||
|  | @ -288,6 +289,7 @@ const Home: ParentComponent = (props) => { | |||
|     const rect = srcElement?.getBoundingClientRect(); | ||||
|     setHeroSrc((x) => Object.assign({}, x, { [BOTTOM_SHEET_HERO]: rect })); | ||||
|     const acct = `${inf.username}@${p.account.site}`; | ||||
|     setTootBottomSheetCache(acct, toot); | ||||
|     navigate(`/${encodeURIComponent(acct)}/${toot.id}`); | ||||
|   }; | ||||
| 
 | ||||
|  |  | |||
|  | @ -1,5 +1,5 @@ | |||
| import { useNavigate, useParams } from "@solidjs/router"; | ||||
| import { createResource, Show, type Component } from "solid-js"; | ||||
| import { createEffect, createResource, Show, type Component } from "solid-js"; | ||||
| import Scaffold from "../material/Scaffold"; | ||||
| import TootThread from "./TootThread"; | ||||
| import { AppBar, IconButton, Toolbar } from "@suid/material"; | ||||
|  | @ -9,13 +9,28 @@ import { isiOS } from "../platform/host"; | |||
| import { createUnauthorizedClient, useSessions } from "../masto/clients"; | ||||
| import { resolveCustomEmoji } from "../masto/toot"; | ||||
| import RegularToot from "./RegularToot"; | ||||
| import type { mastodon } from "masto"; | ||||
| 
 | ||||
| let cachedEntry: [string, mastodon.v1.Status] | undefined; | ||||
| 
 | ||||
| export function setCache(acct: string, status: mastodon.v1.Status) { | ||||
|   cachedEntry = [acct, status] | ||||
| } | ||||
| 
 | ||||
| function getCache(acct: string, id: string) { | ||||
|   if (acct === cachedEntry?.[0] && id === cachedEntry?.[1].id) { | ||||
|     return cachedEntry[1] | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| const TootBottomSheet: Component = (props) => { | ||||
|   const params = useParams<{ acct: string; id: string }>(); | ||||
|   const navigate = useNavigate(); | ||||
|   const allSession = useSessions(); | ||||
|   const acctText = () => decodeURIComponent(params.acct) | ||||
|   const session = () => { | ||||
|     const [inputUsername, inputSite] = decodeURIComponent(params.acct).split( | ||||
|     const [inputUsername, inputSite] = acctText().split( | ||||
|       "@", | ||||
|       2, | ||||
|     ); | ||||
|  | @ -34,7 +49,7 @@ const TootBottomSheet: Component = (props) => { | |||
|     }, | ||||
|   ); | ||||
| 
 | ||||
|   const toot = remoteToot; | ||||
|   const toot = () => remoteToot() ?? getCache(acctText(), params.id); | ||||
| 
 | ||||
|   const tootTitle = () => { | ||||
|     const t = toot(); | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue