import { PlusIcon } from "@heroicons/react/solid"; import classNames from "classnames"; import { useSession } from "next-auth/react"; import { useState } from "react"; import { useLocale } from "@lib/hooks/useLocale"; import { trpc } from "@lib/trpc"; import Loader from "@components/Loader"; import SettingsShell from "@components/SettingsShell"; import Shell, { useMeQuery } from "@components/Shell"; import TeamCreateModal from "@components/team/TeamCreateModal"; import TeamList from "@components/team/TeamList"; import { Alert } from "@components/ui/Alert"; import Button from "@components/ui/Button"; export default function Teams() { const { t } = useLocale(); const { status } = useSession(); const loading = status === "loading"; const [showCreateTeamModal, setShowCreateTeamModal] = useState(false); const [errorMessage, setErrorMessage] = useState(""); const me = useMeQuery(); const { data } = trpc.useQuery(["viewer.teams.list"], { onError: (e) => { setErrorMessage(e.message); }, }); if (loading) return ; const teams = data?.filter((m) => m.accepted) || []; const invites = data?.filter((m) => !m.accepted) || []; const isFreePlan = me.data?.plan === "FREE"; return ( {!!errorMessage && } {isFreePlan && ( {t("plan_upgrade_teams")}} message={ <> {t("to_upgrade_go_to")}{" "} {"https://cal.com/upgrade"} } className="my-4" /> )} {showCreateTeamModal && setShowCreateTeamModal(false)} />}
{invites.length > 0 && (

{t("open_invitations")}

)} {teams.length > 0 && }
); }