| 
									
										
										
										
											2017-11-09 17:10:30 -08:00
										 |  |  | import React from 'react'; | 
					
						
							|  |  |  | import PropTypes from 'prop-types'; | 
					
						
							| 
									
										
										
										
											2016-07-06 11:47:16 -07:00
										 |  |  | import { connect } from 'react-redux'; | 
					
						
							|  |  |  | import { createSelector } from 'reselect'; | 
					
						
							|  |  |  | import { NotificationStack } from 'react-notification'; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-07-31 20:04:01 -07:00
										 |  |  | import { removeToast } from './redux'; | 
					
						
							| 
									
										
										
										
											2016-07-07 20:02:03 -07:00
										 |  |  | import { | 
					
						
							|  |  |  |   submitChallenge, | 
					
						
							| 
									
										
										
										
											2017-11-09 17:10:30 -08:00
										 |  |  |   clickOnReset | 
					
						
							|  |  |  | } from '../routes/Challenges/redux'; | 
					
						
							| 
									
										
										
										
											2016-07-06 11:47:16 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-07-07 20:02:03 -07:00
										 |  |  | const registeredActions = { | 
					
						
							|  |  |  |   submitChallenge, | 
					
						
							| 
									
										
										
										
											2017-11-09 17:10:30 -08:00
										 |  |  |   clickOnReset | 
					
						
							| 
									
										
										
										
											2016-07-07 20:02:03 -07:00
										 |  |  | }; | 
					
						
							| 
									
										
										
										
											2016-07-06 11:47:16 -07:00
										 |  |  | const mapStateToProps = state => ({ toasts: state.toasts }); | 
					
						
							| 
									
										
										
										
											2016-07-07 19:25:31 -07:00
										 |  |  | // we use styles here to overwrite those built into the library
 | 
					
						
							|  |  |  | // but there are some styles applied using
 | 
					
						
							|  |  |  | // regular css in /client/less/toastr.less
 | 
					
						
							| 
									
										
										
										
											2016-07-06 11:47:16 -07:00
										 |  |  | const barStyle = { | 
					
						
							|  |  |  |   fontSize: '2rem', | 
					
						
							|  |  |  |   // null values let our css set the style prop
 | 
					
						
							|  |  |  |   padding: null | 
					
						
							|  |  |  | }; | 
					
						
							| 
									
										
										
										
											2016-07-07 19:25:31 -07:00
										 |  |  | const rightBarStyle = { | 
					
						
							|  |  |  |   ...barStyle, | 
					
						
							|  |  |  |   left: null, | 
					
						
							|  |  |  |   right: '-100%' | 
					
						
							|  |  |  | }; | 
					
						
							| 
									
										
										
										
											2016-07-06 11:47:16 -07:00
										 |  |  | const actionStyle = { | 
					
						
							|  |  |  |   fontSize: '2rem' | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | const addDispatchableActionsToToast = createSelector( | 
					
						
							|  |  |  |   state => state.toasts, | 
					
						
							|  |  |  |   state => state.dispatch, | 
					
						
							|  |  |  |   (toasts, dispatch) => toasts.map(({ position, actionCreator, ...toast }) => { | 
					
						
							|  |  |  |     const activeBarStyle = {}; | 
					
						
							| 
									
										
										
										
											2016-07-07 19:25:31 -07:00
										 |  |  |     let finalBarStyle = barStyle; | 
					
						
							| 
									
										
										
										
											2016-07-06 11:47:16 -07:00
										 |  |  |     if (position !== 'left') { | 
					
						
							|  |  |  |       activeBarStyle.left = null; | 
					
						
							|  |  |  |       activeBarStyle.right = '1rem'; | 
					
						
							| 
									
										
										
										
											2016-07-07 19:25:31 -07:00
										 |  |  |       finalBarStyle = rightBarStyle; | 
					
						
							| 
									
										
										
										
											2016-07-06 11:47:16 -07:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-07-08 12:15:14 -07:00
										 |  |  |     const onClick = !registeredActions[actionCreator] ? | 
					
						
							| 
									
										
										
										
											2016-11-06 10:41:37 +00:00
										 |  |  |       () => { | 
					
						
							|  |  |  |         dispatch(removeToast(toast)); | 
					
						
							|  |  |  |       } : | 
					
						
							| 
									
										
										
										
											2016-07-08 12:15:14 -07:00
										 |  |  |       () => { | 
					
						
							|  |  |  |         dispatch(registeredActions[actionCreator]()); | 
					
						
							|  |  |  |         dispatch(removeToast(toast)); | 
					
						
							|  |  |  |       }; | 
					
						
							| 
									
										
										
										
											2016-07-06 11:47:16 -07:00
										 |  |  |     return { | 
					
						
							|  |  |  |       ...toast, | 
					
						
							| 
									
										
										
										
											2016-07-07 19:25:31 -07:00
										 |  |  |       barStyle: finalBarStyle, | 
					
						
							| 
									
										
										
										
											2016-07-06 11:47:16 -07:00
										 |  |  |       activeBarStyle, | 
					
						
							|  |  |  |       actionStyle, | 
					
						
							|  |  |  |       onClick | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  |   }) | 
					
						
							|  |  |  | ); | 
					
						
							| 
									
										
										
										
											2017-01-12 06:54:43 +00:00
										 |  |  | const propTypes = { | 
					
						
							|  |  |  |   dispatch: PropTypes.func, | 
					
						
							|  |  |  |   toasts: PropTypes.arrayOf(PropTypes.object) | 
					
						
							|  |  |  | }; | 
					
						
							| 
									
										
										
										
											2016-07-06 11:47:16 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | export class Toasts extends React.Component { | 
					
						
							|  |  |  |   constructor(...props) { | 
					
						
							|  |  |  |     super(...props); | 
					
						
							|  |  |  |     this.handleDismiss = this.handleDismiss.bind(this); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-07-07 19:25:31 -07:00
										 |  |  |   styleFactory(index, style) { | 
					
						
							|  |  |  |     return { ...style, bottom: `${4 + index * 8}rem` }; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-07-06 11:47:16 -07:00
										 |  |  |   handleDismiss(notification) { | 
					
						
							|  |  |  |     this.props.dispatch(removeToast(notification)); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   render() { | 
					
						
							|  |  |  |     const { toasts = [], dispatch } = this.props; | 
					
						
							|  |  |  |     return ( | 
					
						
							|  |  |  |       <NotificationStack | 
					
						
							| 
									
										
										
										
											2016-07-07 19:25:31 -07:00
										 |  |  |         activeBarStyle={ this.styleFactory } | 
					
						
							|  |  |  |         barStyle={ this.styleFactory } | 
					
						
							| 
									
										
										
										
											2016-07-06 11:47:16 -07:00
										 |  |  |         notifications={ | 
					
						
							|  |  |  |           addDispatchableActionsToToast({ toasts, dispatch }) | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         onDismiss={ this.handleDismiss } | 
					
						
							|  |  |  |       /> | 
					
						
							|  |  |  |     ); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-01-12 06:54:43 +00:00
										 |  |  | Toasts.displayName = 'Toasts'; | 
					
						
							|  |  |  | Toasts.propTypes = propTypes; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-07-06 11:47:16 -07:00
										 |  |  | export default connect(mapStateToProps)(Toasts); |