import { Check, Code2, Copy, Facebook, Linkedin, Share2 } from 'lucide-react'; import { useRef, useState } from 'react'; import { useOutsideClick } from '../hooks/use-outside-click.ts'; import { useCopyText } from '../hooks/use-copy-text.ts'; import { cn } from '../lib/classname.ts'; import { TwitterIcon } from './ReactIcons/TwitterIcon.tsx'; import { EmbedRoadmapModal } from './CustomRoadmap/EmbedRoadmapModal.tsx'; type ShareRoadmapButtonProps = { roadmapId?: string; description: string; pageUrl: string; allowEmbed?: boolean; }; export function ShareRoadmapButton(props: ShareRoadmapButtonProps) { const { description, pageUrl, allowEmbed = false, roadmapId } = props; const { isCopied, copyText } = useCopyText(); const [isEmbedModalOpen, setIsEmbedModalOpen] = useState(false); const containerRef = useRef(null); const [isDropdownOpen, setIsDropdownOpen] = useState(false); const twitterUrl = `https://twitter.com/intent/tweet?text=${description}&url=${pageUrl}`; const fbUrl = `https://www.facebook.com/sharer/sharer.php?quote=${description}&u=${pageUrl}`; const hnUrl = `https://news.ycombinator.com/submitlink?t=${description}&u=${pageUrl}`; const redditUrl = `https://www.reddit.com/submit?title=${description}&url=${pageUrl}`; const linkedinUrl = `https://www.linkedin.com/shareArticle?mini=true&url=${pageUrl}&title=${description}`; useOutsideClick(containerRef, () => { setIsDropdownOpen(false); }); const embedHtml = ``; return (
{isEmbedModalOpen && ( { setIsEmbedModalOpen(false); }} /> )} {isDropdownOpen && (
{allowEmbed && roadmapId && ( )}
Twitter
Facebook
{'hackernews
Hacker News
{'reddit
Reddit
LinkedIn
)}
); }