import clsx from 'clsx'
import { User } from 'common/user'
import { useState } from 'react'
import { useUser } from 'web/hooks/use-user'
import { withTracking } from 'web/lib/service/analytics'
import { Row } from 'web/components/layout/row'
import { useMemberGroups, useMemberIds } from 'web/hooks/use-group'
import { TextButton } from 'web/components/text-button'
import { Group } from 'common/group'
import { Modal } from 'web/components/layout/modal'
import { Col } from 'web/components/layout/col'
import { joinGroup, leaveGroup } from 'web/lib/firebase/groups'
import { firebaseLogin } from 'web/lib/firebase/users'
import { GroupLinkItem } from 'web/pages/groups'
import toast from 'react-hot-toast'
export function GroupsButton(props: { user: User }) {
const { user } = props
const [isOpen, setIsOpen] = useState(false)
const groups = useMemberGroups(user.id)
return (
<>
setIsOpen(true)}>
{groups?.length ?? ''} Groups
>
)
}
function GroupsDialog(props: {
user: User
groups: Group[]
isOpen: boolean
setIsOpen: (isOpen: boolean) => void
}) {
const { user, groups, isOpen, setIsOpen } = props
return (
{user.name}
@{user.username}
)
}
function GroupsList(props: { groups: Group[] }) {
const { groups } = props
return (
{groups.length === 0 && (
No groups yet...
)}
{groups
.sort((group1, group2) => group2.createdTime - group1.createdTime)
.map((group) => (
))}
)
}
function GroupItem(props: { group: Group; className?: string }) {
const { group, className } = props
return (
)
}
export function JoinOrLeaveGroupButton(props: {
group: Group
small?: boolean
className?: string
}) {
const { group, small, className } = props
const currentUser = useUser()
const memberIds = useMemberIds(group.id)
const isMember = memberIds?.includes(currentUser?.id ?? '') ?? false
const smallStyle =
'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'
if (!currentUser) {
if (!group.anyoneCanJoin)
return Closed
return (
)
}
const onJoinGroup = () => {
joinGroup(group, currentUser.id).catch(() => {
toast.error('Failed to join group')
})
}
const onLeaveGroup = () => {
leaveGroup(group, currentUser.id).catch(() => {
toast.error('Failed to leave group')
})
}
if (isMember) {
return (
)
}
if (!group.anyoneCanJoin)
return Closed
return (
)
}