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
JavaScript
'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