'use client'; import React, { CSSProperties } from 'react'; import { clampSpan, cx } from '@newspaperui/utils'; import { useSection } from '../layout/Section'; import { Caption } from '../text/Caption'; export interface FigureProps { src: string; alt: string; caption?: string; credit?: string; span?: number; className?: string; style?: CSSProperties; } /** * Figure — 图文组合(img + Caption) * * - 将图片与 Caption 组合为语义化 figure 元素 * - 支持 caption 文字说明和 credit 来源标注 * - 自动避免 print 分页断开(break-inside: avoid) * * @example *
*/ export const Figure: React.FC = ({ src, alt, caption, credit, span, className, style, }) => { const section = useSection(); const cols = span ? clampSpan(span, section.columns) : undefined; return (
{alt} {(caption || credit) && {caption}}
); };