2022-09-15 06:46:58 +00:00
|
|
|
import { CheckCircleIcon, PlusCircleIcon } from '@heroicons/react/solid'
|
2022-06-03 04:52:14 +00:00
|
|
|
import clsx from 'clsx'
|
2022-09-15 06:46:58 +00:00
|
|
|
import { useEffect, useRef, useState } from 'react'
|
2022-06-08 20:27:52 +00:00
|
|
|
import { useFollows } from 'web/hooks/use-follows'
|
2022-06-03 04:52:14 +00:00
|
|
|
import { useUser } from 'web/hooks/use-user'
|
2022-06-08 20:27:52 +00:00
|
|
|
import { follow, unfollow } from 'web/lib/firebase/users'
|
2022-06-15 21:34:34 +00:00
|
|
|
import { withTracking } from 'web/lib/service/analytics'
|
2022-06-03 04:52:14 +00:00
|
|
|
|
|
|
|
export function FollowButton(props: {
|
|
|
|
isFollowing: boolean | undefined
|
|
|
|
onFollow: () => void
|
|
|
|
onUnfollow: () => void
|
2022-06-08 20:27:52 +00:00
|
|
|
small?: boolean
|
2022-06-03 04:52:14 +00:00
|
|
|
className?: string
|
|
|
|
}) {
|
2022-06-08 20:27:52 +00:00
|
|
|
const { isFollowing, onFollow, onUnfollow, small, className } = props
|
2022-06-03 04:52:14 +00:00
|
|
|
|
|
|
|
const user = useUser()
|
|
|
|
|
2022-06-08 20:27:52 +00:00
|
|
|
const smallStyle =
|
2022-06-09 04:06:25 +00:00
|
|
|
'btn !btn-xs border-2 border-gray-500 bg-white normal-case text-gray-500 hover:border-gray-500 hover:bg-white hover:text-gray-500'
|
2022-06-08 20:27:52 +00:00
|
|
|
|
2022-06-03 04:52:14 +00:00
|
|
|
if (!user || isFollowing === undefined)
|
|
|
|
return (
|
2022-06-08 20:27:52 +00:00
|
|
|
<button
|
|
|
|
className={clsx('btn btn-sm invisible', small && smallStyle, className)}
|
|
|
|
>
|
2022-06-03 04:52:14 +00:00
|
|
|
Follow
|
|
|
|
</button>
|
|
|
|
)
|
|
|
|
|
|
|
|
if (isFollowing) {
|
|
|
|
return (
|
|
|
|
<button
|
2022-06-08 20:27:52 +00:00
|
|
|
className={clsx(
|
|
|
|
'btn btn-outline btn-sm',
|
|
|
|
small && smallStyle,
|
|
|
|
className
|
|
|
|
)}
|
2022-06-15 21:34:34 +00:00
|
|
|
onClick={withTracking(onUnfollow, 'unfollow')}
|
2022-06-03 04:52:14 +00:00
|
|
|
>
|
|
|
|
Following
|
|
|
|
</button>
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
return (
|
2022-06-08 20:27:52 +00:00
|
|
|
<button
|
|
|
|
className={clsx('btn btn-sm', small && smallStyle, className)}
|
2022-06-15 21:34:34 +00:00
|
|
|
onClick={withTracking(onFollow, 'follow')}
|
2022-06-08 20:27:52 +00:00
|
|
|
>
|
2022-06-03 04:52:14 +00:00
|
|
|
Follow
|
|
|
|
</button>
|
|
|
|
)
|
|
|
|
}
|
2022-06-08 20:27:52 +00:00
|
|
|
|
|
|
|
export function UserFollowButton(props: { userId: string; small?: boolean }) {
|
|
|
|
const { userId, small } = props
|
2022-09-15 06:46:58 +00:00
|
|
|
const user = useUser()
|
|
|
|
const following = useFollows(user?.id)
|
2022-06-08 20:27:52 +00:00
|
|
|
const isFollowing = following?.includes(userId)
|
|
|
|
|
2022-09-15 06:46:58 +00:00
|
|
|
if (!user || user.id === userId) return null
|
2022-06-08 20:27:52 +00:00
|
|
|
|
|
|
|
return (
|
|
|
|
<FollowButton
|
|
|
|
isFollowing={isFollowing}
|
2022-09-15 06:46:58 +00:00
|
|
|
onFollow={() => follow(user.id, userId)}
|
|
|
|
onUnfollow={() => unfollow(user.id, userId)}
|
2022-06-08 20:27:52 +00:00
|
|
|
small={small}
|
|
|
|
/>
|
|
|
|
)
|
|
|
|
}
|
2022-09-15 06:46:58 +00:00
|
|
|
|
|
|
|
export function MiniUserFollowButton(props: { userId: string }) {
|
|
|
|
const { userId } = props
|
|
|
|
const user = useUser()
|
|
|
|
const following = useFollows(user?.id)
|
|
|
|
const isFollowing = following?.includes(userId)
|
|
|
|
const isFirstRender = useRef(true)
|
|
|
|
const [justFollowed, setJustFollowed] = useState(false)
|
|
|
|
|
|
|
|
useEffect(() => {
|
|
|
|
if (isFirstRender.current) {
|
|
|
|
if (isFollowing != undefined) {
|
|
|
|
isFirstRender.current = false
|
|
|
|
}
|
|
|
|
return
|
|
|
|
}
|
|
|
|
if (isFollowing) {
|
|
|
|
setJustFollowed(true)
|
|
|
|
setTimeout(() => {
|
|
|
|
setJustFollowed(false)
|
|
|
|
}, 1000)
|
|
|
|
}
|
|
|
|
}, [isFollowing])
|
|
|
|
|
|
|
|
if (justFollowed) {
|
|
|
|
return (
|
|
|
|
<CheckCircleIcon
|
|
|
|
className={clsx(
|
|
|
|
'text-highlight-blue ml-3 mt-2 h-5 w-5 rounded-full bg-white sm:mr-2'
|
|
|
|
)}
|
|
|
|
aria-hidden="true"
|
|
|
|
/>
|
|
|
|
)
|
|
|
|
}
|
|
|
|
if (
|
|
|
|
!user ||
|
|
|
|
user.id === userId ||
|
|
|
|
isFollowing ||
|
|
|
|
!user ||
|
|
|
|
isFollowing === undefined
|
|
|
|
)
|
|
|
|
return null
|
|
|
|
return (
|
|
|
|
<>
|
|
|
|
<button onClick={withTracking(() => follow(user.id, userId), 'follow')}>
|
|
|
|
<PlusCircleIcon
|
|
|
|
className={clsx(
|
|
|
|
'text-highlight-blue hover:text-hover-blue mt-2 ml-3 h-5 w-5 rounded-full bg-white sm:mr-2'
|
|
|
|
)}
|
|
|
|
aria-hidden="true"
|
|
|
|
/>
|
|
|
|
</button>
|
|
|
|
</>
|
|
|
|
)
|
|
|
|
}
|