* WIP liking markets with tip * Refactor Userlink, add MultiUserLink * Lint * Lint * Fix merge * Fix imports * wip liked contracts list * Cache likes and liked by user ids on contract * Refactor tip amount, reduce to M * Move back to M * Change positioning for large screens
		
			
				
	
	
		
			39 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			39 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import { useEffect, useState } from 'react'
 | |
| import { listenForLikes } from 'web/lib/firebase/users'
 | |
| import { Like } from 'common/like'
 | |
| import { Contract } from 'common/contract'
 | |
| import { getContractFromId } from 'web/lib/firebase/contracts'
 | |
| import { filterDefined } from 'common/util/array'
 | |
| 
 | |
| export const useUserLikes = (userId: string | undefined) => {
 | |
|   const [contractIds, setContractIds] = useState<Like[] | undefined>()
 | |
| 
 | |
|   useEffect(() => {
 | |
|     if (userId) return listenForLikes(userId, setContractIds)
 | |
|   }, [userId])
 | |
| 
 | |
|   return contractIds
 | |
| }
 | |
| export const useUserLikedContracts = (userId: string | undefined) => {
 | |
|   const [likes, setLikes] = useState<Like[] | undefined>()
 | |
|   const [contracts, setContracts] = useState<Contract[] | undefined>()
 | |
| 
 | |
|   useEffect(() => {
 | |
|     if (userId)
 | |
|       return listenForLikes(userId, (likes) => {
 | |
|         setLikes(likes.filter((l) => l.type === 'contract'))
 | |
|       })
 | |
|   }, [userId])
 | |
| 
 | |
|   useEffect(() => {
 | |
|     if (likes)
 | |
|       Promise.all(
 | |
|         likes.map(async (like) => {
 | |
|           return await getContractFromId(like.id)
 | |
|         })
 | |
|       ).then((contracts) => setContracts(filterDefined(contracts)))
 | |
|   }, [likes])
 | |
| 
 | |
|   return contracts
 | |
| }
 |