diff --git a/frontend/src/component/app.jsx b/frontend/src/component/app.jsx index da7081e7c9..8dc7818601 100644 --- a/frontend/src/component/app.jsx +++ b/frontend/src/component/app.jsx @@ -3,12 +3,28 @@ import { Layout, Drawer, Header, Navigation, Content, Footer, FooterSection, FooterDropDownSection, FooterLinkList, Grid, Cell, } from 'react-mdl'; +import { Link } from 'react-router'; import style from './styles.scss'; import ErrorContainer from './error/error-container'; import UserContainer from './user/user-container'; import ShowUserContainer from './user/show-user-container'; +const base = { + name: 'Unleash', + link: '/', +}; + +function replace (input, params) { + if (!params) { + return input; + } + Object.keys(params).forEach(key => { + input = input.replace(`:${key}`, params[key]); + }); + return input; +} + export default class App extends Component { constructor (props) { super(props); @@ -32,6 +48,34 @@ export default class App extends Component { return lastRoute ? lastRoute.pageTitle : ''; } + getTitleWithLinks () { + const { routes, params } = this.props; + const unique = {}; + let result = [base].concat(routes.splice(1).map((routeEntry) => ({ + name: replace(routeEntry.pageTitle, params), + link: replace(routeEntry.link || routeEntry.path, params), + }))).filter(entry => { + if (!unique[entry.link]) { + unique[entry.link] = true; + return true; + } + return false; + }); + + if (result.length > 2) { + result = result.splice(1); + } + return ( + + {result.map((entry, index) => ( + + {entry.name} + {(index + 1) < result.length ? ' / ' : null} + ))} + + ); + } + onOverlayClick = () => this.setState({ drawerActive: false }); render () { @@ -46,7 +90,7 @@ export default class App extends Component {