| 
									
										
										
										
											2017-06-23 14:12:58 -05:00
										 |  |  | import { aboutUrl, donateUrl } from '../common/utils/constantStrings.json'; | 
					
						
							| 
									
										
										
										
											2017-06-05 10:46:04 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-10-06 00:13:51 -07:00
										 |  |  | var main = window.main || {}; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-10-14 21:26:22 -07:00
										 |  |  | main.ga = window.ga || function() {}; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-10-17 19:23:53 -07:00
										 |  |  | $(document).ready(function() { | 
					
						
							| 
									
										
										
										
											2015-09-17 00:18:43 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-05-12 18:52:03 -07:00
										 |  |  |   const { Observable } = window.Rx; | 
					
						
							| 
									
										
										
										
											2015-03-29 20:39:41 +09:00
										 |  |  |   var CSRF_HEADER = 'X-CSRF-Token'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   var setCSRFToken = function(securityToken) { | 
					
						
							|  |  |  |     jQuery.ajaxPrefilter(function(options, _, xhr) { | 
					
						
							|  |  |  |       if (!xhr.crossDomain) { | 
					
						
							|  |  |  |         xhr.setRequestHeader(CSRF_HEADER, securityToken); | 
					
						
							| 
									
										
										
										
											2015-03-12 00:03:56 +09:00
										 |  |  |       } | 
					
						
							|  |  |  |     }); | 
					
						
							| 
									
										
										
										
											2015-03-29 20:39:41 +09:00
										 |  |  |   }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   setCSRFToken($('meta[name="csrf-token"]').attr('content')); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-01-21 01:46:48 -05:00
										 |  |  |   $('img').on('error', function() { | 
					
						
							| 
									
										
										
										
											2015-11-06 16:35:57 -08:00
										 |  |  |     $(this) | 
					
						
							|  |  |  |       .unbind('error') | 
					
						
							|  |  |  |       .attr( | 
					
						
							|  |  |  |         'src', | 
					
						
							|  |  |  |         'https://s3.amazonaws.com/freecodecamp/camper-image-placeholder.png' | 
					
						
							|  |  |  |       ); | 
					
						
							| 
									
										
										
										
											2015-04-13 02:41:42 -04:00
										 |  |  |   }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-26 14:54:56 +04:00
										 |  |  |   $.each($('.sr-only'), function(i, span) { | 
					
						
							|  |  |  |     if ($(span).text() === ' Complete') { | 
					
						
							|  |  |  |       $(span).parents('p').addClass('manip-hidden'); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-05-12 18:52:03 -07:00
										 |  |  |   function addAlert(message = '', type = 'alert-info') { | 
					
						
							|  |  |  |     return $('.flashMessage').append($(`
 | 
					
						
							|  |  |  |       <div class='alert ${type}'> | 
					
						
							|  |  |  |         <button class='close' type='button', data-dismiss='alert'> | 
					
						
							|  |  |  |           <span class='ion-close-circled' /> | 
					
						
							|  |  |  |         </Button> | 
					
						
							|  |  |  |         <div>${message}</div> | 
					
						
							|  |  |  |       </div> | 
					
						
							|  |  |  |     `));
 | 
					
						
							| 
									
										
										
										
											2016-04-08 18:13:41 -04:00
										 |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-05-12 18:52:03 -07:00
										 |  |  |   function toggleNightMode() { | 
					
						
							|  |  |  |     if (!main.userId) { | 
					
						
							| 
									
										
										
										
											2016-05-12 21:28:29 -07:00
										 |  |  |       return addAlert('You must be logged in to use our themes.'); | 
					
						
							| 
									
										
										
										
											2016-05-12 18:52:03 -07:00
										 |  |  |     } | 
					
						
							|  |  |  |     const iframe$ = document.getElementById('map-aside-frame'); | 
					
						
							|  |  |  |     const body$ = $('body'); | 
					
						
							|  |  |  |     if (iframe$) { | 
					
						
							|  |  |  |       iframe$.src = iframe$.src; | 
					
						
							| 
									
										
										
										
											2016-04-08 18:13:41 -04:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-05-12 18:52:03 -07:00
										 |  |  |     body$.hide(); | 
					
						
							|  |  |  |     let updateThemeTo; | 
					
						
							|  |  |  |     if (body$.hasClass('night')) { | 
					
						
							|  |  |  |       body$.removeClass('night'); | 
					
						
							|  |  |  |       updateThemeTo = 'default'; | 
					
						
							| 
									
										
										
										
											2016-04-08 18:13:41 -04:00
										 |  |  |     } else { | 
					
						
							| 
									
										
										
										
											2016-05-12 18:52:03 -07:00
										 |  |  |       body$.addClass('night'); | 
					
						
							|  |  |  |       updateThemeTo = 'night'; | 
					
						
							| 
									
										
										
										
											2016-04-08 18:13:41 -04:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-05-12 18:52:03 -07:00
										 |  |  |     body$.fadeIn('100'); | 
					
						
							|  |  |  |     const options = { | 
					
						
							|  |  |  |       url: `/api/users/${main.userId}/update-theme`, | 
					
						
							|  |  |  |       type: 'POST', | 
					
						
							|  |  |  |       data: { theme: updateThemeTo }, | 
					
						
							|  |  |  |       dataType: 'json' | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  |     return $.ajax(options) | 
					
						
							| 
									
										
										
										
											2017-01-21 01:46:48 -05:00
										 |  |  |       .done(() => console.log('theme updated successfully')) | 
					
						
							| 
									
										
										
										
											2016-05-12 18:52:03 -07:00
										 |  |  |       .fail(err => { | 
					
						
							|  |  |  |         let message; | 
					
						
							|  |  |  |         try { | 
					
						
							|  |  |  |           message = JSON.parse(err.responseText).error.message; | 
					
						
							|  |  |  |         } catch (error) { | 
					
						
							|  |  |  |           return null; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         if (!message) { | 
					
						
							|  |  |  |           return null; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         return addAlert(message); | 
					
						
							|  |  |  |       }); | 
					
						
							| 
									
										
										
										
											2016-04-08 18:13:41 -04:00
										 |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-05-12 18:52:03 -07:00
										 |  |  |   Observable.merge( | 
					
						
							|  |  |  |     Observable.fromEvent($('#night-mode'), 'click'), | 
					
						
							|  |  |  |     Observable.create(observer => { | 
					
						
							|  |  |  |       window.Mousetrap.bind('g t n', () => observer.onNext()); | 
					
						
							|  |  |  |     }) | 
					
						
							|  |  |  |   ) | 
					
						
							|  |  |  |     .debounce(500) | 
					
						
							|  |  |  |     .subscribe(toggleNightMode, err => console.error(err)); | 
					
						
							| 
									
										
										
										
											2016-04-08 18:13:41 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |   // Hot Keys
 | 
					
						
							|  |  |  |   window.Mousetrap.bind('g n n', () => { | 
					
						
							|  |  |  |     // Next Challenge
 | 
					
						
							|  |  |  |     window.location = '/challenges/next-challenge'; | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  |   window.Mousetrap.bind('g n m', () => { | 
					
						
							|  |  |  |     // Map
 | 
					
						
							|  |  |  |     window.location = '/map'; | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  |   window.Mousetrap.bind('g n a', () => { | 
					
						
							|  |  |  |     // About
 | 
					
						
							| 
									
										
										
										
											2017-06-23 14:12:58 -05:00
										 |  |  |     window.location = aboutUrl; | 
					
						
							| 
									
										
										
										
											2016-04-08 18:13:41 -04:00
										 |  |  |   }); | 
					
						
							| 
									
										
										
										
											2017-06-05 10:46:04 -05:00
										 |  |  |   window.Mousetrap.bind('g n d', () => { | 
					
						
							|  |  |  |     // Donate
 | 
					
						
							|  |  |  |     window.location = donateUrl; | 
					
						
							| 
									
										
										
										
											2016-04-08 18:13:41 -04:00
										 |  |  |   }); | 
					
						
							|  |  |  |   window.Mousetrap.bind('g n o', () => { | 
					
						
							|  |  |  |     // Settings
 | 
					
						
							|  |  |  |     window.location = '/settings'; | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  |   window.Mousetrap.bind('g n r', () => { | 
					
						
							|  |  |  |     // Repo
 | 
					
						
							|  |  |  |     window.location = 'https://github.com/freecodecamp/freecodecamp/'; | 
					
						
							|  |  |  |   }); | 
					
						
							| 
									
										
										
										
											2016-04-14 19:49:19 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |   (function getFlyer() { | 
					
						
							|  |  |  |     const flyerKey = '__flyerId__'; | 
					
						
							|  |  |  |     $.ajax({ | 
					
						
							|  |  |  |       url: '/api/flyers/findOne', | 
					
						
							|  |  |  |       method: 'GET', | 
					
						
							|  |  |  |       dataType: 'JSON', | 
					
						
							|  |  |  |       data: { filter: { order: 'id DESC' } } | 
					
						
							|  |  |  |     }) | 
					
						
							|  |  |  |     // log error
 | 
					
						
							|  |  |  |     .fail(err => console.error(err)) | 
					
						
							|  |  |  |     .done(flyer => { | 
					
						
							|  |  |  |       const lastFlyerId = localStorage.getItem(flyerKey); | 
					
						
							|  |  |  |       if ( | 
					
						
							|  |  |  |         !flyer || | 
					
						
							|  |  |  |         !flyer.isActive || | 
					
						
							|  |  |  |         lastFlyerId === flyer.id | 
					
						
							|  |  |  |       ) { | 
					
						
							|  |  |  |         return; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       $('#dismiss-bill').on('click', () => { | 
					
						
							|  |  |  |         localStorage.setItem(flyerKey, flyer.id); | 
					
						
							|  |  |  |       }); | 
					
						
							|  |  |  |       $('#bill-content').html(flyer.message); | 
					
						
							|  |  |  |       $('#bill-board').fadeIn(); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  |   }()); | 
					
						
							| 
									
										
										
										
											2014-11-06 17:38:47 -08:00
										 |  |  | }); |