import classNames from 'classnames'; import * as React from 'react'; import type { ConfigConsumerProps } from '../config-provider'; import { ConfigConsumer } from '../config-provider'; import type { AntAnchor } from './Anchor'; import AnchorContext from './context'; export interface AnchorLinkProps { prefixCls?: string; href: string; target?: string; title: React.ReactNode; children?: React.ReactNode; className?: string; } const AnchorLink: React.FC = props => { const { href = '#', title, prefixCls: customizePrefixCls, children, className, target } = props; const context = React.useContext(AnchorContext); const { registerLink, unregisterLink, scrollTo, onClick, activeLink } = context || {}; React.useEffect(() => { registerLink?.(href); return () => { unregisterLink?.(href); }; }, [href]); const handleClick = (e: React.MouseEvent) => { onClick?.(e, { title, href }); scrollTo?.(href); }; return ( {({ getPrefixCls }: ConfigConsumerProps) => { const prefixCls = getPrefixCls('anchor', customizePrefixCls); const active = activeLink === href; const wrapperClassName = classNames(`${prefixCls}-link`, className, { [`${prefixCls}-link-active`]: active, }); const titleClassName = classNames(`${prefixCls}-link-title`, { [`${prefixCls}-link-title-active`]: active, }); return (
{title} {children}
); }}
); }; export default AnchorLink;