import React from 'react' import Router from 'next/router' import { AdjustmentsIcon, PlusSmIcon, ArrowSmRightIcon, } from '@heroicons/react/solid' import clsx from 'clsx' import { Page } from 'web/components/page' import { Col } from 'web/components/layout/col' import { ContractSearch, SORTS } from 'web/components/contract-search' import { User } from 'common/user' import { useTracking } from 'web/hooks/use-tracking' import { track } from 'web/lib/service/analytics' import { useSaveReferral } from 'web/hooks/use-save-referral' import { Sort } from 'web/components/contract-search' import { Group } from 'common/group' import { SiteLink } from 'web/components/site-link' import { useUser } from 'web/hooks/use-user' import { useMemberGroups } from 'web/hooks/use-group' import { Button } from 'web/components/button' import { getHomeItems } from '../../../components/arrange-home' import { Title } from 'web/components/title' import { Row } from 'web/components/layout/row' import { ProbChangeTable } from 'web/components/contract/prob-change-table' import { groupPath } from 'web/lib/firebase/groups' import { usePortfolioHistory } from 'web/hooks/use-portfolio-history' import { formatMoney } from 'common/util/format' import { useProbChanges } from 'web/hooks/use-prob-changes' import { ProfitBadge } from 'web/components/bets-list' import { calculatePortfolioProfit } from 'common/calculate-metrics' export default function Home() { const user = useUser() useTracking('view home') useSaveReferral() const groups = useMemberGroups(user?.id) ?? [] const { sections } = getHomeItems(groups, user?.homeSections ?? []) return ( <EditButton /> </Row> <DailyProfitAndBalance className="" user={user} /> </Row> {sections.map((item) => { const { id } = item if (id === 'daily-movers') { return <DailyMoversSection key={id} userId={user?.id} /> } const sort = SORTS.find((sort) => sort.value === id) if (sort) return ( <SearchSection key={id} label={sort.value === 'newest' ? 'New for you' : sort.label} sort={sort.value} followed={sort.value === 'newest'} user={user} /> ) const group = groups.find((g) => g.id === id) if (group) return <GroupSection key={id} group={group} user={user} /> return null })} </Col> <button type="button" className="fixed bottom-[70px] right-3 z-20 inline-flex items-center rounded-full border border-transparent bg-indigo-600 p-3 text-white shadow-sm hover:bg-indigo-700 focus:outline-none focus:ring-2 focus:ring-indigo-500 focus:ring-offset-2 lg:hidden" onClick={() => { Router.push('/create') track('mobile create button') }} > <PlusSmIcon className="h-8 w-8" aria-hidden="true" /> </button> </Page> ) } function SearchSection(props: { label: string user: User | null | undefined | undefined sort: Sort yourBets?: boolean followed?: boolean }) { const { label, user, sort, yourBets, followed } = props return ( <Col> <SectionHeader label={label} href={`/home?s=${sort}`} /> <ContractSearch user={user} defaultSort={sort} additionalFilter={ yourBets ? { yourBets: true } : followed ? { followed: true } : undefined } noControls maxResults={6} headerClassName="sticky" persistPrefix={`experimental-home-${sort}`} /> </Col> ) } function GroupSection(props: { group: Group user: User | null | undefined | undefined }) { const { group, user } = props return ( <Col> <SectionHeader label={group.name} href={groupPath(group.slug)} /> <ContractSearch user={user} defaultSort={'score'} additionalFilter={{ groupSlug: group.slug }} noControls maxResults={6} headerClassName="sticky" persistPrefix={`experimental-home-${group.slug}`} /> </Col> ) } function DailyMoversSection(props: { userId: string | null | undefined }) { const { userId } = props const changes = useProbChanges(userId ?? '') return ( <Col className="gap-2"> <SectionHeader label="Daily movers" href="daily-movers" /> <ProbChangeTable changes={changes} /> </Col> ) } function SectionHeader(props: { label: string; href: string }) { const { label, href } = props return ( <Row className="mb-3 items-center justify-between"> <SiteLink className="text-xl" href={href}> {label}{' '} <ArrowSmRightIcon className="mb-0.5 inline h-6 w-6 text-gray-500" aria-hidden="true" /> </SiteLink> </Row> ) } function EditButton(props: { className?: string }) { const { className } = props return ( <SiteLink href="/experimental/home/edit"> <Button size="sm" color="gray-white" className={clsx(className, 'flex')}> <AdjustmentsIcon className={clsx('h-[24px] w-5')} aria-hidden="true" /> </Button> </SiteLink> ) } function DailyProfitAndBalance(props: { user: User | null | undefined className?: string }) { const { user, className } = props const metrics = usePortfolioHistory(user?.id ?? '', 'daily') ?? [] const [first, last] = [metrics[0], metrics[metrics.length - 1]] if (first === undefined || last === undefined) return null const profit = calculatePortfolioProfit(last) - calculatePortfolioProfit(first) const profitPercent = profit / first.investmentValue return ( <Row className={'gap-4'}> <Col> <div className="text-gray-500">Daily profit</div> <Row className={clsx(className, 'items-center text-lg')}> <span>{formatMoney(profit)}</span>{' '} <ProfitBadge profitPercent={profitPercent * 100} /> </Row> </Col> <Col> <div className="text-gray-500">Streak</div> <Row className={clsx(className, 'items-center text-lg')}> <span>🔥 {user?.currentBettingStreak ?? 0}</span> </Row> </Col> </Row> ) }