1
0
mirror of https://github.com/Pomax/BezierInfo-2.git synced 2025-02-25 10:02:58 +01:00
BezierInfo-2/components/Navigation.jsx
2016-03-20 10:15:52 -07:00

39 lines
1.0 KiB
JavaScript

var React = require('react');
var ReactRouter = require('react-router');
var Link = ReactRouter.Link;
var sections = require("./sections");
var sectionPages = Object.keys(sections);
var Navigation = React.createClass({
generateNavItem: function(name, entry) {
var Type = sections[name];
var title = Type.getDefaultProps().title;
var link = <a href={'#' + name}>{ title }</a>;
if (this.props.fullNav) {
link = <Link to={name}>{title}</Link>;
}
var last = sectionPages.length - 1;
if (entry===last) entry = null;
return <li key={name} data-number={entry}>{link}</li>;
},
generateNav: function() {
if (this.props.compact) return null;
return (
<div ref="navigation">
<navigation className={ this.props.compact ? "compact" : null }>
<ul className="navigation">
{ sectionPages.map(this.generateNavItem) }
</ul>
</navigation>
</div>
);
},
render: function() {
return this.generateNav();
}
});
module.exports = Navigation;