import * as React from 'react'; import { cloneElement } from 'react'; import BreadcrumbItem from './BreadcrumbItem'; const defaultNameRender = (breadcrumbName, route, params) => { if (!breadcrumbName) { return null; } const paramsKeys = Object.keys(params).join('|'); const name = breadcrumbName.replace( new RegExp(`:(${paramsKeys})`, 'g'), (replacement, key) => params[key] || replacement ); return {name}; }; interface BreadcrumbProps { prefixCls?: string; routes?: Array; params?: Object; separator?: string | React.ReactNode; linkRender?: (link, name, paths: Array) => React.ReactNode; nameRender?: (breadcrumbName, route, params) => React.ReactNode; style?: React.CSSProperties; } export default class Breadcrumb extends React.Component { static Item: any; static defaultProps = { prefixCls: 'ant-breadcrumb', separator: '/', linkRender: (href, name) => {name}, nameRender: defaultNameRender, }; static propTypes = { prefixCls: React.PropTypes.string, separator: React.PropTypes.oneOfType([ React.PropTypes.string, React.PropTypes.element, ]), routes: React.PropTypes.array, params: React.PropTypes.object, linkRender: React.PropTypes.func, nameRender: React.PropTypes.func, }; render() { let crumbs; const { separator, prefixCls, routes, params, children, linkRender, nameRender } = this.props; if (routes && routes.length > 0) { const paths = []; const lastPath = routes.length - 1; crumbs = routes.map((route, i) => { route.path = route.path || ''; let path = route.path.replace(/^\//, ''); Object.keys(params).forEach(key => { path = path.replace(`:${key}`, params[key]); }); if (path) { paths.push(path); } const name = nameRender(route.breadcrumbName, route, params); if (name) { const link = (i === lastPath) ? name : linkRender(`/${paths.join('/')}`, name, paths); return {link}; } return null; }); } else { crumbs = React.Children.map(children, (element: any, index) => { return cloneElement(element, { separator, key: index, }); }); } return (
{crumbs}
); } }