{props.heading}
{props.subtitle}
import Link from "next/link"; import React, { Fragment, useEffect } from "react"; import { useRouter } from "next/router"; import { useSession } from "next-auth/client"; import { Menu, Transition } from "@headlessui/react"; import { collectPageParameters, telemetryEventTypes, useTelemetry } from "../lib/telemetry"; import { SelectorIcon } from "@heroicons/react/outline"; import { CalendarIcon, ClockIcon, PuzzleIcon, CogIcon, ChatAltIcon, LogoutIcon, ExternalLinkIcon, LinkIcon, } from "@heroicons/react/solid"; import Logo from "./Logo"; function classNames(...classes) { return classes.filter(Boolean).join(" "); } export default function Shell(props) { const router = useRouter(); const [session, loading] = useSession(); const telemetry = useTelemetry(); const navigation = [ { name: "Event Types", href: "/event-types", icon: LinkIcon, current: router.pathname.startsWith("/event-types"), }, { name: "Bookings", href: "/bookings", icon: ClockIcon, current: router.pathname.startsWith("/bookings"), }, { name: "Availability", href: "/availability", icon: CalendarIcon, current: router.pathname.startsWith("/availability"), }, { name: "Integrations", href: "/integrations", icon: PuzzleIcon, current: router.pathname.startsWith("/integrations"), }, { name: "Settings", href: "/settings/profile", icon: CogIcon, current: router.pathname.startsWith("/settings"), }, ]; useEffect(() => { telemetry.withJitsu((jitsu) => { return jitsu.track(telemetryEventTypes.pageView, collectPageParameters(router.pathname)); }); }, [telemetry]); if (!loading && !session) { router.replace("/auth/login"); } return session ? (
{props.subtitle}