"use client"; import { Badge } from "@/components/ui/badge"; import { Carousel, type CarouselApi, CarouselContent, CarouselItem, } from "@/components/ui/carousel"; import { HoverCard, HoverCardContent, HoverCardTrigger, } from "@/components/ui/hover-card"; import { cn } from "@/lib/utils"; import { ArrowLeftIcon, ArrowRightIcon } from "lucide-react"; import { type ComponentProps, createContext, useCallback, useContext, useEffect, useState, } from "react"; export type InlineCitationProps = ComponentProps<"span">; export const InlineCitation = ({ className, ...props }: InlineCitationProps) => ( ); export type InlineCitationTextProps = ComponentProps<"span">; export const InlineCitationText = ({ className, ...props }: InlineCitationTextProps) => ( ); export type InlineCitationCardProps = ComponentProps; export const InlineCitationCard = (props: InlineCitationCardProps) => ( ); export type InlineCitationCardTriggerProps = ComponentProps & { sources: string[]; }; export const InlineCitationCardTrigger = ({ sources, className, ...props }: InlineCitationCardTriggerProps) => ( {sources[0] ? ( <> {new URL(sources[0]).hostname}{" "} {sources.length > 1 && `+${sources.length - 1}`} ) : ( "unknown" )} ); export type InlineCitationCardBodyProps = ComponentProps<"div">; export const InlineCitationCardBody = ({ className, ...props }: InlineCitationCardBodyProps) => ( ); const CarouselApiContext = createContext(undefined); const useCarouselApi = () => { const context = useContext(CarouselApiContext); return context; }; export type InlineCitationCarouselProps = ComponentProps; export const InlineCitationCarousel = ({ className, children, ...props }: InlineCitationCarouselProps) => { const [api, setApi] = useState(); return ( {children} ); }; export type InlineCitationCarouselContentProps = ComponentProps<"div">; export const InlineCitationCarouselContent = ( props: InlineCitationCarouselContentProps ) => ; export type InlineCitationCarouselItemProps = ComponentProps<"div">; export const InlineCitationCarouselItem = ({ className, ...props }: InlineCitationCarouselItemProps) => ( ); export type InlineCitationCarouselHeaderProps = ComponentProps<"div">; export const InlineCitationCarouselHeader = ({ className, ...props }: InlineCitationCarouselHeaderProps) => (
); export type InlineCitationCarouselIndexProps = ComponentProps<"div">; export const InlineCitationCarouselIndex = ({ children, className, ...props }: InlineCitationCarouselIndexProps) => { const api = useCarouselApi(); const [current, setCurrent] = useState(0); const [count, setCount] = useState(0); useEffect(() => { if (!api) { return; } setCount(api.scrollSnapList().length); setCurrent(api.selectedScrollSnap() + 1); api.on("select", () => { setCurrent(api.selectedScrollSnap() + 1); }); }, [api]); return (
{children ?? `${current}/${count}`}
); }; export type InlineCitationCarouselPrevProps = ComponentProps<"button">; export const InlineCitationCarouselPrev = ({ className, ...props }: InlineCitationCarouselPrevProps) => { const api = useCarouselApi(); const handleClick = useCallback(() => { if (api) { api.scrollPrev(); } }, [api]); return ( ); }; export type InlineCitationCarouselNextProps = ComponentProps<"button">; export const InlineCitationCarouselNext = ({ className, ...props }: InlineCitationCarouselNextProps) => { const api = useCarouselApi(); const handleClick = useCallback(() => { if (api) { api.scrollNext(); } }, [api]); return ( ); }; export type InlineCitationSourceProps = ComponentProps<"div"> & { title?: string; url?: string; description?: string; }; export const InlineCitationSource = ({ title, url, description, className, children, ...props }: InlineCitationSourceProps) => (
{title && (

{title}

)} {url && (

{url}

)} {description && (

{description}

)} {children}
); export type InlineCitationQuoteProps = ComponentProps<"blockquote">; export const InlineCitationQuote = ({ children, className, ...props }: InlineCitationQuoteProps) => (
{children}
);