mirror of
				https://github.com/aykhans/slash-e.git
				synced 2025-10-26 06:49:21 +00:00 
			
		
		
		
	feat: add favicon cache
This commit is contained in:
		
							
								
								
									
										41
									
								
								web/src/stores/v1/favicon.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										41
									
								
								web/src/stores/v1/favicon.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,41 @@ | ||||
| import { create } from "zustand"; | ||||
| import { persist } from "zustand/middleware"; | ||||
| import * as api from "../../helpers/api"; | ||||
|  | ||||
| interface FaviconState { | ||||
|   cache: { | ||||
|     [key: string]: string; | ||||
|   }; | ||||
|   getOrFetchUrlFavicon: (url: string) => Promise<string>; | ||||
| } | ||||
|  | ||||
| const useFaviconStore = create<FaviconState>()( | ||||
|   persist( | ||||
|     (set, get) => ({ | ||||
|       cache: {}, | ||||
|       getOrFetchUrlFavicon: async (url: string) => { | ||||
|         const cache = get().cache; | ||||
|         if (cache[url]) { | ||||
|           return cache[url]; | ||||
|         } | ||||
|  | ||||
|         try { | ||||
|           const { data: favicon } = await api.getUrlFavicon(url); | ||||
|           if (favicon) { | ||||
|             cache[url] = favicon; | ||||
|             set(cache); | ||||
|             return favicon; | ||||
|           } | ||||
|         } catch (error) { | ||||
|           // do nothing | ||||
|         } | ||||
|         return ""; | ||||
|       }, | ||||
|     }), | ||||
|     { | ||||
|       name: "favicon_cache", | ||||
|     } | ||||
|   ) | ||||
| ); | ||||
|  | ||||
| export default useFaviconStore; | ||||
		Reference in New Issue
	
	Block a user
	 Steven
					Steven