import React from 'react'; import { cloneElement } from 'react'; import warning from '../_util/warning'; import BreadcrumbItem from './BreadcrumbItem'; import classNames from 'classnames'; export interface BreadcrumbProps { prefixCls?: string; routes?: Array; params?: Object; separator?: React.ReactNode; itemRender?: (route: any, params: any, routes: Array, paths: Array) => React.ReactNode; style?: React.CSSProperties; className?: string; }; function getBreadcrumbName(route, params) { if (!route.breadcrumbName) { return null; } const paramsKeys = Object.keys(params).join('|'); const name = route.breadcrumbName.replace( new RegExp(`:(${paramsKeys})`, 'g'), (replacement, key) => params[key] || replacement, ); return name; } function defaultItemRender(route, params, routes, paths) { const isLastItem = routes.indexOf(route) === routes.length - 1; const name = getBreadcrumbName(route, params); return isLastItem ? {name} : {name}; } export default class Breadcrumb extends React.Component { static Item: any; static defaultProps = { prefixCls: 'ant-breadcrumb', separator: '/', }; static propTypes = { prefixCls: React.PropTypes.string, separator: React.PropTypes.node, routes: React.PropTypes.array, params: React.PropTypes.object, linkRender: React.PropTypes.func, nameRender: React.PropTypes.func, }; componentDidMount() { const props = this.props; warning( !('linkRender' in props || 'nameRender' in props), '`linkRender` and `nameRender` are removed, please use `itemRender` instead, ' + 'see: http://u.ant.design/item-render.', ); } render() { let crumbs; const { separator, prefixCls, style, className, routes, params = {}, children, itemRender = defaultItemRender, } = this.props; if (routes && routes.length > 0) { const paths: string[] = []; crumbs = routes.map((route) => { route.path = route.path || ''; let path: string = route.path.replace(/^\//, ''); Object.keys(params).forEach(key => { path = path.replace(`:${key}`, params[key]); }); if (path) { paths.push(path); } return ( {itemRender(route, params, routes, paths)} ); }); } else if (children) { crumbs = React.Children.map(children, (element: any, index) => { if (!element) { return element; } warning( element.type && element.type.__ANT_BREADCRUMB_ITEM, 'Breadcrumb only accepts Breadcrumb.Item as it\'s children', ); return cloneElement(element, { separator, key: index, }); }); } return (
{crumbs}
); } }