import clsx from 'clsx'
import { PencilIcon } from '@heroicons/react/outline'
import { User } from 'common/user'
import { useEffect, useState } from 'react'
import { useFollowers, useFollows } from 'web/hooks/use-follows'
import { prefetchUsers, useUser } from 'web/hooks/use-user'
import { FollowList } from './follow-list'
import { Col } from './layout/col'
import { Modal } from './layout/modal'
import { Tabs } from './layout/tabs'
import { useDiscoverUsers } from 'web/hooks/use-users'
export function FollowingButton(props: { user: User }) {
const { user } = props
const [open, setOpen] = useState(false)
const followingIds = useFollows(user.id)
const followerIds = useFollowers(user.id)
return (
<>
setOpen(true)}
>
{followingIds?.length ?? ''}{' '}
Following
>
)
}
export function EditFollowingButton(props: { user: User; className?: string }) {
const { user, className } = props
const [open, setOpen] = useState(false)
const followingIds = useFollows(user.id)
const followerIds = useFollowers(user.id)
return (
setOpen(true)}
>
Following
)
}
export function FollowersButton(props: { user: User }) {
const { user } = props
const [isOpen, setIsOpen] = useState(false)
const followingIds = useFollows(user.id)
const followerIds = useFollowers(user.id)
return (
<>
setIsOpen(true)}
>
{followerIds?.length ?? ''}{' '}
Followers
>
)
}
function FollowingFollowersDialog(props: {
user: User
followingIds: string[]
followerIds: string[]
defaultTab: 'following' | 'followers'
isOpen: boolean
setIsOpen: (isOpen: boolean) => void
}) {
const { user, followingIds, followerIds, defaultTab, isOpen, setIsOpen } =
props
useEffect(() => {
prefetchUsers([...followingIds, ...followerIds])
}, [followingIds, followerIds])
const currentUser = useUser()
const discoverUserIds = useDiscoverUsers()
useEffect(() => {
prefetchUsers(discoverUserIds)
}, [discoverUserIds])
return (
{user.name}
@{user.username}
,
},
{
title: 'Followers',
content: ,
},
...(currentUser
? [
{
title: 'Discover',
content: ,
},
]
: []),
]}
defaultIndex={defaultTab === 'following' ? 0 : 1}
/>
)
}