| 
									
										
										
										
											2017-11-09 17:10:30 -08:00
										 |  |  | import React from 'react'; | 
					
						
							|  |  |  | import PropTypes from 'prop-types'; | 
					
						
							| 
									
										
										
										
											2016-06-22 14:55:35 -07:00
										 |  |  | import { connect } from 'react-redux'; | 
					
						
							|  |  |  | import { createSelector } from 'reselect'; | 
					
						
							| 
									
										
										
										
											2016-03-22 22:13:05 -07:00
										 |  |  | import PureComponent from 'react-pure-render/component'; | 
					
						
							|  |  |  | import FA from 'react-fontawesome'; | 
					
						
							|  |  |  | import { Panel } from 'react-bootstrap'; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-07-31 20:04:01 -07:00
										 |  |  | import ns from './ns.json'; | 
					
						
							| 
									
										
										
										
											2016-03-22 22:13:05 -07:00
										 |  |  | import Block from './Block.jsx'; | 
					
						
							| 
									
										
										
										
											2016-07-14 17:13:48 -07:00
										 |  |  | import { | 
					
						
							| 
									
										
										
										
											2017-07-31 20:04:01 -07:00
										 |  |  |   toggleThisPanel, | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-07-14 17:13:48 -07:00
										 |  |  |   makePanelOpenSelector, | 
					
						
							|  |  |  |   makePanelHiddenSelector | 
					
						
							| 
									
										
										
										
											2017-07-31 20:04:01 -07:00
										 |  |  | } from './redux'; | 
					
						
							|  |  |  | import { makeSuperBlockSelector } from '../entities'; | 
					
						
							| 
									
										
										
										
											2016-03-22 22:13:05 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-22 14:55:35 -07:00
										 |  |  | const dispatchActions = { toggleThisPanel }; | 
					
						
							| 
									
										
										
										
											2016-07-14 17:13:48 -07:00
										 |  |  | // make selectors unique to each component
 | 
					
						
							|  |  |  | // see
 | 
					
						
							|  |  |  | // reactjs/reselect
 | 
					
						
							|  |  |  | // sharing-selectors-with-props-across-multiple-components
 | 
					
						
							| 
									
										
										
										
											2017-07-31 20:04:01 -07:00
										 |  |  | function makeMapStateToProps(_, { dashedName }) { | 
					
						
							| 
									
										
										
										
											2016-07-14 17:13:48 -07:00
										 |  |  |   return createSelector( | 
					
						
							| 
									
										
										
										
											2017-07-31 20:04:01 -07:00
										 |  |  |     makeSuperBlockSelector(dashedName), | 
					
						
							|  |  |  |     makePanelOpenSelector(dashedName), | 
					
						
							|  |  |  |     makePanelHiddenSelector(dashedName), | 
					
						
							|  |  |  |     (superBlock, isOpen, isHidden) => ({ | 
					
						
							| 
									
										
										
										
											2016-07-14 17:13:48 -07:00
										 |  |  |       isOpen, | 
					
						
							|  |  |  |       isHidden, | 
					
						
							|  |  |  |       dashedName, | 
					
						
							| 
									
										
										
										
											2017-07-31 20:04:01 -07:00
										 |  |  |       title: superBlock.title || dashedName, | 
					
						
							|  |  |  |       blocks: superBlock.blocks || [], | 
					
						
							| 
									
										
										
										
											2016-07-14 17:13:48 -07:00
										 |  |  |       message: superBlock.message | 
					
						
							|  |  |  |     }) | 
					
						
							|  |  |  |   ); | 
					
						
							| 
									
										
										
										
											2017-07-31 20:04:01 -07:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2016-07-14 17:13:48 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-01-12 06:54:43 +00:00
										 |  |  | const propTypes = { | 
					
						
							|  |  |  |   blocks: PropTypes.array, | 
					
						
							|  |  |  |   dashedName: PropTypes.string, | 
					
						
							|  |  |  |   isHidden: PropTypes.bool, | 
					
						
							|  |  |  |   isOpen: PropTypes.bool, | 
					
						
							|  |  |  |   message: PropTypes.string, | 
					
						
							|  |  |  |   title: PropTypes.string, | 
					
						
							|  |  |  |   toggleThisPanel: PropTypes.func | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-22 14:55:35 -07:00
										 |  |  | export class SuperBlock extends PureComponent { | 
					
						
							|  |  |  |   constructor(...props) { | 
					
						
							|  |  |  |     super(...props); | 
					
						
							|  |  |  |     this.handleSelect = this.handleSelect.bind(this); | 
					
						
							| 
									
										
										
										
											2016-06-21 16:28:13 -07:00
										 |  |  |   } | 
					
						
							|  |  |  |   handleSelect(eventKey, e) { | 
					
						
							|  |  |  |     e.preventDefault(); | 
					
						
							|  |  |  |     this.props.toggleThisPanel(eventKey); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-22 22:13:05 -07:00
										 |  |  |   renderBlocks(blocks) { | 
					
						
							|  |  |  |     if (!Array.isArray(blocks) || !blocks.length) { | 
					
						
							| 
									
										
										
										
											2017-07-31 20:04:01 -07:00
										 |  |  |       return null; | 
					
						
							| 
									
										
										
										
											2016-03-22 22:13:05 -07:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-06-22 14:55:35 -07:00
										 |  |  |     return blocks.map(dashedName => ( | 
					
						
							|  |  |  |       <Block | 
					
						
							|  |  |  |         dashedName={ dashedName } | 
					
						
							|  |  |  |         key={ dashedName } | 
					
						
							|  |  |  |       /> | 
					
						
							|  |  |  |     )); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   renderMessage(message) { | 
					
						
							|  |  |  |     if (!message) { | 
					
						
							|  |  |  |       return null; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return ( | 
					
						
							| 
									
										
										
										
											2017-07-31 20:04:01 -07:00
										 |  |  |       <div className={ `${ns}-block-description` }> | 
					
						
							| 
									
										
										
										
											2016-06-22 14:55:35 -07:00
										 |  |  |         { message } | 
					
						
							|  |  |  |       </div> | 
					
						
							|  |  |  |     ); | 
					
						
							| 
									
										
										
										
											2016-03-22 22:13:05 -07:00
										 |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-22 20:25:49 -07:00
										 |  |  |   renderHeader(isOpen, title, isCompleted) { | 
					
						
							|  |  |  |     return ( | 
					
						
							| 
									
										
										
										
											2017-07-31 20:04:01 -07:00
										 |  |  |       <div className={ isCompleted ? 'faded' : '' }> | 
					
						
							| 
									
										
										
										
											2016-06-22 20:25:49 -07:00
										 |  |  |         <FA | 
					
						
							| 
									
										
										
										
											2017-07-31 20:04:01 -07:00
										 |  |  |           className={ `${ns}-caret` } | 
					
						
							| 
									
										
										
										
											2016-06-22 20:25:49 -07:00
										 |  |  |           name={ isOpen ? 'caret-down' : 'caret-right' } | 
					
						
							| 
									
										
										
										
											2017-07-31 20:04:01 -07:00
										 |  |  |           size='lg' | 
					
						
							| 
									
										
										
										
											2016-06-22 20:25:49 -07:00
										 |  |  |         /> | 
					
						
							|  |  |  |         { title } | 
					
						
							| 
									
										
										
										
											2017-07-31 20:04:01 -07:00
										 |  |  |       </div> | 
					
						
							| 
									
										
										
										
											2016-06-22 20:25:49 -07:00
										 |  |  |     ); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-22 22:13:05 -07:00
										 |  |  |   render() { | 
					
						
							| 
									
										
										
										
											2016-06-22 14:55:35 -07:00
										 |  |  |     const { | 
					
						
							|  |  |  |       title, | 
					
						
							|  |  |  |       dashedName, | 
					
						
							|  |  |  |       blocks, | 
					
						
							|  |  |  |       message, | 
					
						
							| 
									
										
										
										
											2016-07-14 17:13:48 -07:00
										 |  |  |       isOpen, | 
					
						
							|  |  |  |       isHidden | 
					
						
							| 
									
										
										
										
											2016-06-22 14:55:35 -07:00
										 |  |  |     } = this.props; | 
					
						
							| 
									
										
										
										
											2016-07-14 17:13:48 -07:00
										 |  |  |     if (isHidden) { | 
					
						
							|  |  |  |       return null; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-03-22 22:13:05 -07:00
										 |  |  |     return ( | 
					
						
							|  |  |  |       <Panel | 
					
						
							| 
									
										
										
										
											2017-07-31 20:04:01 -07:00
										 |  |  |         bsClass={ `${ns}-accordion-panel` } | 
					
						
							| 
									
										
										
										
											2016-03-22 22:13:05 -07:00
										 |  |  |         collapsible={ true } | 
					
						
							| 
									
										
										
										
											2016-06-21 16:28:13 -07:00
										 |  |  |         eventKey={ dashedName || title } | 
					
						
							| 
									
										
										
										
											2016-06-22 14:55:35 -07:00
										 |  |  |         expanded={ isOpen } | 
					
						
							| 
									
										
										
										
											2016-06-22 20:25:49 -07:00
										 |  |  |         header={ this.renderHeader(isOpen, title) } | 
					
						
							| 
									
										
										
										
											2016-03-22 22:13:05 -07:00
										 |  |  |         id={ title } | 
					
						
							| 
									
										
										
										
											2016-06-21 16:28:13 -07:00
										 |  |  |         key={ dashedName || title } | 
					
						
							|  |  |  |         onSelect={ this.handleSelect } | 
					
						
							| 
									
										
										
										
											2016-06-09 16:02:51 -07:00
										 |  |  |         > | 
					
						
							| 
									
										
										
										
											2016-06-22 14:55:35 -07:00
										 |  |  |         { this.renderMessage(message) } | 
					
						
							| 
									
										
										
										
											2017-07-31 20:04:01 -07:00
										 |  |  |         <div className={ `${ns}-accordion-block` }> | 
					
						
							| 
									
										
										
										
											2016-03-22 22:13:05 -07:00
										 |  |  |           { this.renderBlocks(blocks) } | 
					
						
							|  |  |  |         </div> | 
					
						
							|  |  |  |       </Panel> | 
					
						
							|  |  |  |     ); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2016-06-22 14:55:35 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-01-12 06:54:43 +00:00
										 |  |  | SuperBlock.displayName = 'SuperBlock'; | 
					
						
							|  |  |  | SuperBlock.propTypes = propTypes; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-22 14:55:35 -07:00
										 |  |  | export default connect( | 
					
						
							| 
									
										
										
										
											2016-07-14 17:13:48 -07:00
										 |  |  |   makeMapStateToProps, | 
					
						
							| 
									
										
										
										
											2016-06-22 14:55:35 -07:00
										 |  |  |   dispatchActions | 
					
						
							|  |  |  | )(SuperBlock); |