2016-01-11 14:00:09 +01:00
|
|
|
'use strict';
|
|
|
|
|
|
|
|
import React from 'react';
|
|
|
|
|
|
|
|
const AppRouteWrapper = React.createClass({
|
|
|
|
propTypes: {
|
|
|
|
children: React.PropTypes.oneOfType([
|
|
|
|
React.PropTypes.arrayOf(React.PropTypes.element),
|
|
|
|
React.PropTypes.element
|
|
|
|
]).isRequired
|
|
|
|
},
|
|
|
|
|
|
|
|
render() {
|
2016-02-26 10:20:56 +01:00
|
|
|
let { children, ...propsToPropagate } = this.props;
|
2016-01-11 14:00:09 +01:00
|
|
|
|
|
|
|
// If there are more props given, propagate them into the child routes by cloning the routes
|
|
|
|
if (Object.keys(propsToPropagate).length) {
|
2016-02-26 10:20:56 +01:00
|
|
|
children = React.Children.map(children, (child) => {
|
2016-01-11 14:00:09 +01:00
|
|
|
return React.cloneElement(child, propsToPropagate);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
return (
|
2016-02-05 10:38:59 +01:00
|
|
|
<div className="container ascribe-body">
|
2016-02-26 10:20:56 +01:00
|
|
|
{children}
|
2016-01-11 14:00:09 +01:00
|
|
|
</div>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
export default AppRouteWrapper;
|