+ Moved away from deprecated navbar components and props + Removed mixin from NavItem + Updated stylesheet so the `.container` react-bootstrap adds doesn't impact nav positioning
		
			
				
	
	
		
			92 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			92 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| import React from 'react';
 | |
| import classNames from 'classnames';
 | |
| 
 | |
| export default React.createClass({
 | |
|   displayName: 'FCCNavItem',
 | |
| 
 | |
|   propTypes: {
 | |
|     active: React.PropTypes.bool,
 | |
|     'aria-controls': React.PropTypes.string,
 | |
|     children: React.PropTypes.node,
 | |
|     className: React.PropTypes.string,
 | |
|     disabled: React.PropTypes.bool,
 | |
|     eventKey: React.PropTypes.any,
 | |
|     href: React.PropTypes.string,
 | |
|     linkId: React.PropTypes.string,
 | |
|     onSelect: React.PropTypes.func,
 | |
|     role: React.PropTypes.string,
 | |
|     target: React.PropTypes.string,
 | |
|     title: React.PropTypes.node
 | |
|   },
 | |
| 
 | |
|   getDefaultProps() {
 | |
|     return {
 | |
|       href: '#'
 | |
|     };
 | |
|   },
 | |
| 
 | |
|   handleClick(e) {
 | |
|     if (this.props.onSelect) {
 | |
|       e.preventDefault();
 | |
| 
 | |
|       if (!this.props.disabled) {
 | |
|         this.props.onSelect(
 | |
|           this.props.eventKey,
 | |
|           this.props.href,
 | |
|           this.props.target
 | |
|         );
 | |
|       }
 | |
|     }
 | |
|   },
 | |
| 
 | |
|   render() {
 | |
|     let {
 | |
|       role,
 | |
|       linkId,
 | |
|       disabled,
 | |
|       active,
 | |
|       href,
 | |
|       title,
 | |
|       target,
 | |
|       children,
 | |
|       'aria-controls': ariaControls,  // eslint-disable-line react/prop-types
 | |
|       className,
 | |
|       ...props
 | |
|     } = this.props;
 | |
| 
 | |
|     const linkClassName = classNames(className, {
 | |
|       // 'active': active, we don't actually use the active class
 | |
|       // but it is used for a11y below
 | |
|       'disabled': disabled
 | |
|     });
 | |
| 
 | |
|     let linkProps = {
 | |
|       role,
 | |
|       href,
 | |
|       title,
 | |
|       target,
 | |
|       id: linkId,
 | |
|       onClick: this.handleClick,
 | |
|       ref: 'anchor'
 | |
|     };
 | |
| 
 | |
|     if (!role && href === '#') {
 | |
|       linkProps.role = 'button';
 | |
|     }
 | |
| 
 | |
|     return (
 | |
|       <li
 | |
|         {...props}
 | |
|         role='presentation'>
 | |
|         <a
 | |
|           { ...linkProps }
 | |
|           aria-controls={ ariaControls }
 | |
|           aria-selected={ active }
 | |
|           className={ linkClassName }>
 | |
|           { children }
 | |
|         </a>
 | |
|       </li>
 | |
|     );
 | |
|   }
 | |
| });
 |