UNPKG

nextjs-link-preview

Version:

A simple, lightweight Next.js component for displaying beautiful link preview cards with preset image support

94 lines (89 loc) 4.83 kB
'use client'; 'use strict'; Object.defineProperty(exports, '__esModule', { value: true }); var React = require('react'); // Inline SVG data URIs for preset images const PRESET_IMAGES = { github: ``, npm: "https://avatars.githubusercontent.com/u/6078720?s=200&v=4" }; const sizeConfig = { small: { imageHeight: "120px", imageWidth: "120px", titleSize: "14px", descriptionSize: "12px", padding: "8px", lineClamp: 1 }, medium: { imageHeight: "200px", imageWidth: "200px", titleSize: "16px", descriptionSize: "14px", padding: "12px", lineClamp: 2 }, large: { imageHeight: "300px", imageWidth: "280px", titleSize: "20px", descriptionSize: "16px", padding: "16px", lineClamp: 3 } }; function LinkPreview({ url, title, description, image, preset, size = "medium", layout = "vertical", width = "100%", height = "auto", className = "" }) { const config = sizeConfig[size]; const isHorizontal = layout === "horizontal"; // Use preset image if no custom image provided const imageUrl = image || (preset ? PRESET_IMAGES[preset] : undefined); return (React.createElement("a", { href: url, target: "_blank", rel: "noopener noreferrer", className: `link-preview ${className}`, style: { display: isHorizontal ? "flex" : "block", flexDirection: isHorizontal ? "row" : undefined, width, maxWidth: isHorizontal ? undefined : "400px", height, textDecoration: "none", color: "inherit", border: "1px solid #e0e0e0", borderRadius: "8px", overflow: "hidden", transition: "box-shadow 0.3s" }, onMouseEnter: (e) => { e.currentTarget.style.boxShadow = "0 4px 12px rgba(0,0,0,0.15)"; }, onMouseLeave: (e) => { e.currentTarget.style.boxShadow = "none"; } }, imageUrl && (React.createElement("div", { style: { width: isHorizontal ? config.imageWidth : "100%", height: isHorizontal ? "100%" : config.imageHeight, minHeight: isHorizontal ? config.imageHeight : undefined, flexShrink: isHorizontal ? 0 : undefined, backgroundImage: `url(${imageUrl})`, backgroundSize: preset ? "contain" : "cover", backgroundPosition: "center", backgroundRepeat: "no-repeat", backgroundColor: preset ? "#f6f8fa" : "transparent" } })), React.createElement("div", { style: { padding: config.padding, flex: isHorizontal ? 1 : undefined, display: "flex", flexDirection: "column", justifyContent: "center" } }, React.createElement("h3", { style: { margin: "0 0 8px 0", fontSize: config.titleSize } }, title), description && (React.createElement("p", { style: { margin: 0, fontSize: config.descriptionSize, color: "#666", display: "-webkit-box", WebkitLineClamp: config.lineClamp, WebkitBoxOrient: "vertical", overflow: "hidden" } }, description))))); } exports.LinkPreview = LinkPreview; exports.default = LinkPreview; //# sourceMappingURL=index.js.map