| 
									
										
										
										
											2015-06-17 21:04:28 -07:00
										 |  |  | import React, { PropTypes } from 'react'; | 
					
						
							| 
									
										
										
										
											2015-07-24 17:52:07 -07:00
										 |  |  | import { contain } from 'thundercats-react'; | 
					
						
							| 
									
										
										
										
											2015-07-04 08:16:42 -07:00
										 |  |  | import { Row } from 'react-bootstrap'; | 
					
						
							| 
									
										
										
										
											2015-06-17 21:04:28 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-03 17:46:58 -07:00
										 |  |  | import { Nav } from './components/Nav'; | 
					
						
							| 
									
										
										
										
											2015-06-17 21:04:28 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-24 17:52:07 -07:00
										 |  |  | export default contain( | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     store: 'appStore', | 
					
						
							|  |  |  |     fetchAction: 'appActions.getUser', | 
					
						
							|  |  |  |     getPayload(props) { | 
					
						
							|  |  |  |       return { | 
					
						
							|  |  |  |         isPrimed: !!props.username | 
					
						
							|  |  |  |       }; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  |   React.createClass({ | 
					
						
							|  |  |  |     displayName: 'FreeCodeCamp', | 
					
						
							| 
									
										
										
										
											2015-06-17 21:04:28 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-24 17:52:07 -07:00
										 |  |  |     propTypes: { | 
					
						
							| 
									
										
										
										
											2015-07-24 21:54:19 -07:00
										 |  |  |       children: PropTypes.node, | 
					
						
							|  |  |  |       points: PropTypes.number, | 
					
						
							| 
									
										
										
										
											2015-07-29 10:16:48 -07:00
										 |  |  |       picture: PropTypes.string, | 
					
						
							|  |  |  |       title: PropTypes.string, | 
					
						
							|  |  |  |       username: PropTypes.string | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     componentDidMount() { | 
					
						
							|  |  |  |       const title = this.props.title; | 
					
						
							|  |  |  |       this.setTitle(title); | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     componentWillReceiveProps(nextProps) { | 
					
						
							|  |  |  |       if (nextProps.title !== this.props.title) { | 
					
						
							|  |  |  |         this.setTitle(nextProps.title); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     setTitle(title) { | 
					
						
							|  |  |  |       const doc = typeof document !== 'undefined' ? document : {}; | 
					
						
							|  |  |  |       doc.title = title; | 
					
						
							| 
									
										
										
										
											2015-07-24 17:52:07 -07:00
										 |  |  |     }, | 
					
						
							| 
									
										
										
										
											2015-06-17 21:04:28 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-24 17:52:07 -07:00
										 |  |  |     render() { | 
					
						
							| 
									
										
										
										
											2015-07-24 21:54:19 -07:00
										 |  |  |       const { username, points, picture } = this.props; | 
					
						
							|  |  |  |       const navProps = { username, points, picture }; | 
					
						
							| 
									
										
										
										
											2015-07-24 17:52:07 -07:00
										 |  |  |       return ( | 
					
						
							|  |  |  |         <div> | 
					
						
							| 
									
										
										
										
											2015-07-24 21:54:19 -07:00
										 |  |  |           <Nav | 
					
						
							|  |  |  |             { ...navProps }/> | 
					
						
							| 
									
										
										
										
											2015-07-24 17:52:07 -07:00
										 |  |  |           <Row> | 
					
						
							|  |  |  |             { this.props.children } | 
					
						
							|  |  |  |           </Row> | 
					
						
							|  |  |  |         </div> | 
					
						
							|  |  |  |       ); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   }) | 
					
						
							|  |  |  | ); |