| 
									
										
										
										
											2016-04-24 21:54:48 -07:00
										 |  |  | import { Observable } from 'rx'; | 
					
						
							| 
									
										
										
										
											2016-01-27 11:34:44 -08:00
										 |  |  | import { createAction } from 'redux-actions'; | 
					
						
							|  |  |  | import types from './types'; | 
					
						
							| 
									
										
										
										
											2017-01-02 23:04:07 -08:00
										 |  |  | import noop from 'lodash/noop'; | 
					
						
							| 
									
										
										
										
											2016-01-27 11:34:44 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-07-21 16:35:37 -07:00
										 |  |  | const throwIfUndefined = () => { | 
					
						
							|  |  |  |   throw new TypeError('Argument must not be of  type `undefined`'); | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export const createEventMeta = ({ | 
					
						
							|  |  |  |   category = throwIfUndefined, | 
					
						
							|  |  |  |   action = throwIfUndefined, | 
					
						
							|  |  |  |   label, | 
					
						
							|  |  |  |   value | 
					
						
							|  |  |  | } = throwIfUndefined) => ({ | 
					
						
							|  |  |  |   analytics: { | 
					
						
							|  |  |  |     type: 'event', | 
					
						
							|  |  |  |     category, | 
					
						
							|  |  |  |     action, | 
					
						
							|  |  |  |     label, | 
					
						
							|  |  |  |     value | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export const trackEvent = createAction( | 
					
						
							|  |  |  |   types.analytics, | 
					
						
							|  |  |  |   null, | 
					
						
							|  |  |  |   createEventMeta | 
					
						
							|  |  |  | ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export const trackSocial = createAction( | 
					
						
							|  |  |  |   types.analytics, | 
					
						
							|  |  |  |   null, | 
					
						
							|  |  |  |   ( | 
					
						
							|  |  |  |     network = throwIfUndefined, | 
					
						
							|  |  |  |     action = throwIfUndefined, | 
					
						
							|  |  |  |     target = throwIfUndefined | 
					
						
							|  |  |  |   ) => ({ | 
					
						
							|  |  |  |     analytics: { | 
					
						
							|  |  |  |       type: 'event', | 
					
						
							|  |  |  |       network, | 
					
						
							|  |  |  |       action, | 
					
						
							|  |  |  |       target | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   }) | 
					
						
							|  |  |  | ); | 
					
						
							| 
									
										
										
										
											2016-01-27 11:34:44 -08:00
										 |  |  | // updateTitle(title: String) => Action
 | 
					
						
							|  |  |  | export const updateTitle = createAction(types.updateTitle); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // fetchUser() => Action
 | 
					
						
							|  |  |  | // used in combination with fetch-user-saga
 | 
					
						
							|  |  |  | export const fetchUser = createAction(types.fetchUser); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-07-19 16:36:34 -07:00
										 |  |  | // addUser(
 | 
					
						
							| 
									
										
										
										
											2016-06-20 11:35:19 -07:00
										 |  |  | //   entities: { [userId]: User }
 | 
					
						
							|  |  |  | // ) => Action
 | 
					
						
							|  |  |  | export const addUser = createAction( | 
					
						
							|  |  |  |   types.addUser, | 
					
						
							|  |  |  |   () => {}, | 
					
						
							|  |  |  |   entities => ({ entities }) | 
					
						
							|  |  |  | ); | 
					
						
							|  |  |  | export const updateThisUser = createAction(types.updateThisUser); | 
					
						
							| 
									
										
										
										
											2016-06-23 20:05:30 -07:00
										 |  |  | export const showSignIn = createAction(types.showSignIn); | 
					
						
							| 
									
										
										
										
											2016-08-03 15:32:22 -07:00
										 |  |  | export const loadCurrentChallenge = createAction( | 
					
						
							|  |  |  |   types.loadCurrentChallenge, | 
					
						
							|  |  |  |   null, | 
					
						
							|  |  |  |   () => createEventMeta({ | 
					
						
							|  |  |  |     category: 'Nav', | 
					
						
							|  |  |  |     action: 'clicked', | 
					
						
							|  |  |  |     label: 'fcc logo clicked' | 
					
						
							|  |  |  |   }) | 
					
						
							|  |  |  | ); | 
					
						
							| 
									
										
										
										
											2016-08-03 15:26:05 -07:00
										 |  |  | export const updateMyCurrentChallenge = createAction( | 
					
						
							|  |  |  |   types.updateMyCurrentChallenge, | 
					
						
							|  |  |  |   (username, currentChallengeId) => ({ username, currentChallengeId }) | 
					
						
							|  |  |  | ); | 
					
						
							| 
									
										
										
										
											2016-01-27 11:34:44 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-20 11:35:19 -07:00
										 |  |  | // updateUserPoints(username: String, points: Number) => Action
 | 
					
						
							|  |  |  | export const updateUserPoints = createAction( | 
					
						
							|  |  |  |   types.updateUserPoints, | 
					
						
							|  |  |  |   (username, points) => ({ username, points }) | 
					
						
							|  |  |  | ); | 
					
						
							| 
									
										
										
										
											2016-07-19 16:36:34 -07:00
										 |  |  | // updateUserFlag(username: String, flag: String) => Action
 | 
					
						
							| 
									
										
										
										
											2016-07-16 10:38:06 -07:00
										 |  |  | export const updateUserFlag = createAction( | 
					
						
							|  |  |  |   types.updateUserFlag, | 
					
						
							|  |  |  |   (username, flag) => ({ username, flag }) | 
					
						
							|  |  |  | ); | 
					
						
							| 
									
										
										
										
											2016-07-19 16:36:34 -07:00
										 |  |  | // updateUserEmail(username: String, email: String) => Action
 | 
					
						
							|  |  |  | export const updateUserEmail = createAction( | 
					
						
							|  |  |  |   types.updateUserFlag, | 
					
						
							|  |  |  |   (username, email) => ({ username, email }) | 
					
						
							|  |  |  | ); | 
					
						
							|  |  |  | // updateUserLang(username: String, lang: String) => Action
 | 
					
						
							|  |  |  | export const updateUserLang = createAction( | 
					
						
							|  |  |  |   types.updateUserLang, | 
					
						
							| 
									
										
										
										
											2016-11-23 21:53:42 +00:00
										 |  |  |   (username, lang) => ({ username, languageTag: lang }) | 
					
						
							| 
									
										
										
										
											2016-07-19 16:36:34 -07:00
										 |  |  | ); | 
					
						
							| 
									
										
										
										
											2016-08-11 16:41:03 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | // updateUserChallenge(
 | 
					
						
							|  |  |  | //   username: String,
 | 
					
						
							|  |  |  | //   challengeInfo: Object
 | 
					
						
							|  |  |  | // ) => Action
 | 
					
						
							|  |  |  | export const updateUserChallenge = createAction( | 
					
						
							|  |  |  |   types.updateUserChallenge, | 
					
						
							|  |  |  |   (username, challengeInfo) => ({ username, challengeInfo }) | 
					
						
							|  |  |  | ); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-07-20 15:06:44 -07:00
										 |  |  | export const updateAppLang = createAction(types.updateAppLang); | 
					
						
							| 
									
										
										
										
											2016-06-20 13:38:49 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-09 16:02:51 -07:00
										 |  |  | // used when server needs client to redirect
 | 
					
						
							|  |  |  | export const delayedRedirect = createAction(types.delayedRedirect); | 
					
						
							| 
									
										
										
										
											2016-03-02 22:19:04 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  | // hardGoTo(path: String) => Action
 | 
					
						
							|  |  |  | export const hardGoTo = createAction(types.hardGoTo); | 
					
						
							| 
									
										
										
										
											2016-03-05 21:06:04 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-10 17:21:46 -08:00
										 |  |  | // data
 | 
					
						
							|  |  |  | export const updateChallengesData = createAction(types.updateChallengesData); | 
					
						
							|  |  |  | export const updateHikesData = createAction(types.updateHikesData); | 
					
						
							| 
									
										
										
										
											2016-04-24 21:54:48 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-05-31 15:26:24 -07:00
										 |  |  | export const createErrorObservable = error => Observable.just({ | 
					
						
							| 
									
										
										
										
											2016-04-24 21:54:48 -07:00
										 |  |  |   type: types.handleError, | 
					
						
							|  |  |  |   error | 
					
						
							|  |  |  | }); | 
					
						
							| 
									
										
										
										
											2016-07-19 16:36:34 -07:00
										 |  |  | // doActionOnError(
 | 
					
						
							|  |  |  | //   actionCreator: (() => Action|Null)
 | 
					
						
							|  |  |  | // ) => (error: Error) => Observable[Action]
 | 
					
						
							|  |  |  | export const doActionOnError = actionCreator => error => Observable.of( | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     type: types.handleError, | 
					
						
							|  |  |  |     error | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  |   actionCreator() | 
					
						
							|  |  |  | ); | 
					
						
							| 
									
										
										
										
											2016-06-03 13:43:42 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-08-05 14:05:57 -07:00
										 |  |  | export const toggleNightMode = createAction( | 
					
						
							|  |  |  |   types.toggleNightMode, | 
					
						
							|  |  |  |   // we use this function to avoid hanging onto the eventObject
 | 
					
						
							|  |  |  |   // so that react can recycle it
 | 
					
						
							|  |  |  |   () => null | 
					
						
							|  |  |  | ); | 
					
						
							|  |  |  | // updateTheme(theme: /night|default/) => Action
 | 
					
						
							|  |  |  | export const updateTheme = createAction(types.updateTheme); | 
					
						
							|  |  |  | // addThemeToBody(theme: /night|default/) => Action
 | 
					
						
							|  |  |  | export const addThemeToBody = createAction(types.addThemeToBody); | 
					
						
							| 
									
										
										
										
											2017-01-02 23:04:07 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  | export const openDropdown = createAction(types.openDropdown, noop); | 
					
						
							|  |  |  | export const closeDropdown = createAction(types.closeDropdown, noop); |