| 
									
										
										
										
											2016-03-31 11:05:32 +02:00
										 |  |  | /* global Module */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Magic Mirror | 
					
						
							|  |  |  |  * Module: Calendar | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * By Michael Teeuw http://michaelteeuw.nl
 | 
					
						
							|  |  |  |  * MIT Licensed. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-14 15:23:03 +02:00
										 |  |  | Module.register("calendar", { | 
					
						
							| 
									
										
										
										
											2016-03-31 11:05:32 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	// Define module defaults
 | 
					
						
							|  |  |  | 	defaults: { | 
					
						
							|  |  |  | 		maximumEntries: 10, // Total Maximum Entries
 | 
					
						
							| 
									
										
										
										
											2016-04-03 19:52:13 +02:00
										 |  |  | 		maximumNumberOfDays: 365, | 
					
						
							| 
									
										
										
										
											2016-03-31 11:05:32 +02:00
										 |  |  | 		displaySymbol: true, | 
					
						
							| 
									
										
										
										
											2016-05-10 11:58:05 -06:00
										 |  |  | 		defaultSymbol: "calendar", // Fontawesome Symbol see http://fontawesome.io/cheatsheet/
 | 
					
						
							| 
									
										
										
										
											2016-04-26 22:34:12 +02:00
										 |  |  | 		displayRepeatingCountTitle: false, | 
					
						
							| 
									
										
										
										
											2016-10-14 15:23:03 +02:00
										 |  |  | 		defaultRepeatingCountTitle: "", | 
					
						
							| 
									
										
										
										
											2016-04-03 19:52:13 +02:00
										 |  |  | 		maxTitleLength: 25, | 
					
						
							| 
									
										
										
										
											2016-03-31 11:05:32 +02:00
										 |  |  | 		fetchInterval: 5 * 60 * 1000, // Update every 5 minutes.
 | 
					
						
							|  |  |  | 		animationSpeed: 2000, | 
					
						
							| 
									
										
										
										
											2016-04-03 19:52:13 +02:00
										 |  |  | 		fade: true, | 
					
						
							| 
									
										
										
										
											2016-05-10 01:01:00 -06:00
										 |  |  | 		urgency: 7, | 
					
						
							|  |  |  | 		timeFormat: "relative", | 
					
						
							| 
									
										
										
										
											2016-11-10 17:26:29 +01:00
										 |  |  | 		dateFormat: "MMM Do", | 
					
						
							| 
									
										
										
										
											2016-09-04 00:05:02 +02:00
										 |  |  | 		getRelative: 6, | 
					
						
							| 
									
										
										
										
											2016-03-31 11:05:32 +02:00
										 |  |  | 		fadePoint: 0.25, // Start on 1/4th of the list.
 | 
					
						
							| 
									
										
										
										
											2016-04-05 14:35:11 -04:00
										 |  |  | 		calendars: [ | 
					
						
							| 
									
										
										
										
											2016-03-31 11:05:32 +02:00
										 |  |  | 			{ | 
					
						
							| 
									
										
										
										
											2016-04-05 14:35:11 -04:00
										 |  |  | 				symbol: "calendar", | 
					
						
							|  |  |  | 				url: "http://www.calendarlabs.com/templates/ical/US-Holidays.ics", | 
					
						
							| 
									
										
										
										
											2016-03-31 11:05:32 +02:00
										 |  |  | 			}, | 
					
						
							|  |  |  | 		], | 
					
						
							|  |  |  | 		titleReplace: { | 
					
						
							| 
									
										
										
										
											2016-06-06 12:05:41 +02:00
										 |  |  | 			"De verjaardag van ": "", | 
					
						
							|  |  |  | 			"'s birthday": "" | 
					
						
							| 
									
										
										
										
											2016-04-05 10:01:54 +02:00
										 |  |  | 		}, | 
					
						
							| 
									
										
										
										
											2016-10-14 15:23:03 +02:00
										 |  |  | 		broadcastEvents: true | 
					
						
							| 
									
										
										
										
											2016-03-31 11:05:32 +02:00
										 |  |  | 	}, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// Define required scripts.
 | 
					
						
							| 
									
										
										
										
											2016-10-14 15:23:03 +02:00
										 |  |  | 	getStyles: function () { | 
					
						
							| 
									
										
										
										
											2016-04-05 14:35:11 -04:00
										 |  |  | 		return ["calendar.css", "font-awesome.css"]; | 
					
						
							| 
									
										
										
										
											2016-03-31 11:05:32 +02:00
										 |  |  | 	}, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// Define required scripts.
 | 
					
						
							| 
									
										
										
										
											2016-10-14 15:23:03 +02:00
										 |  |  | 	getScripts: function () { | 
					
						
							| 
									
										
										
										
											2016-04-05 14:35:11 -04:00
										 |  |  | 		return ["moment.js"]; | 
					
						
							| 
									
										
										
										
											2016-03-31 11:05:32 +02:00
										 |  |  | 	}, | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-21 01:04:00 +02:00
										 |  |  | 	// Define required translations.
 | 
					
						
							| 
									
										
										
										
											2016-10-14 15:23:03 +02:00
										 |  |  | 	getTranslations: function () { | 
					
						
							| 
									
										
										
										
											2016-05-11 12:38:41 +02:00
										 |  |  | 		// The translations for the defaut modules are defined in the core translation files.
 | 
					
						
							|  |  |  | 		// Therefor we can just return false. Otherwise we should have returned a dictionairy.
 | 
					
						
							| 
									
										
										
										
											2016-06-04 20:32:55 -06:00
										 |  |  | 		// If you're trying to build your own module including translations, check out the documentation.
 | 
					
						
							| 
									
										
										
										
											2016-05-11 12:38:41 +02:00
										 |  |  | 		return false; | 
					
						
							| 
									
										
										
										
											2016-04-21 01:04:00 +02:00
										 |  |  | 	}, | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-31 11:05:32 +02:00
										 |  |  | 	// Override start method.
 | 
					
						
							| 
									
										
										
										
											2016-10-14 15:23:03 +02:00
										 |  |  | 	start: function () { | 
					
						
							| 
									
										
										
										
											2016-04-05 14:35:11 -04:00
										 |  |  | 		Log.log("Starting module: " + this.name); | 
					
						
							| 
									
										
										
										
											2016-03-31 11:05:32 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		// Set locale.
 | 
					
						
							|  |  |  | 		moment.locale(config.language); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		for (var c in this.config.calendars) { | 
					
						
							|  |  |  | 			var calendar = this.config.calendars[c]; | 
					
						
							| 
									
										
										
										
											2016-04-05 14:35:11 -04:00
										 |  |  | 			calendar.url = calendar.url.replace("webcal://", "http://"); | 
					
						
							| 
									
										
										
										
											2016-09-08 17:36:30 +02:00
										 |  |  | 			this.addCalendar(calendar.url, calendar.user, calendar.pass); | 
					
						
							| 
									
										
										
										
											2016-03-31 11:05:32 +02:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		this.calendarData = {}; | 
					
						
							| 
									
										
										
										
											2016-04-05 10:01:54 +02:00
										 |  |  | 		this.loaded = false; | 
					
						
							| 
									
										
										
										
											2016-03-31 11:05:32 +02:00
										 |  |  | 	}, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// Override socket notification handler.
 | 
					
						
							| 
									
										
										
										
											2016-10-14 15:23:03 +02:00
										 |  |  | 	socketNotificationReceived: function (notification, payload) { | 
					
						
							| 
									
										
										
										
											2016-04-05 14:35:11 -04:00
										 |  |  | 		if (notification === "CALENDAR_EVENTS") { | 
					
						
							| 
									
										
										
										
											2016-03-31 11:05:32 +02:00
										 |  |  | 			if (this.hasCalendarURL(payload.url)) { | 
					
						
							|  |  |  | 				this.calendarData[payload.url] = payload.events; | 
					
						
							| 
									
										
										
										
											2016-04-05 10:01:54 +02:00
										 |  |  | 				this.loaded = true; | 
					
						
							| 
									
										
										
										
											2016-10-14 15:23:03 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 				if (this.config.broadcastEvents) { | 
					
						
							|  |  |  | 					this.broadcastEvents(); | 
					
						
							|  |  |  | 				} | 
					
						
							| 
									
										
										
										
											2016-03-31 11:05:32 +02:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2016-04-05 14:35:11 -04:00
										 |  |  | 		} else if (notification === "FETCH_ERROR") { | 
					
						
							|  |  |  | 			Log.error("Calendar Error. Could not fetch calendar: " + payload.url); | 
					
						
							|  |  |  | 		} else if (notification === "INCORRECT_URL") { | 
					
						
							|  |  |  | 			Log.error("Calendar Error. Incorrect url: " + payload.url); | 
					
						
							| 
									
										
										
										
											2016-03-31 11:05:32 +02:00
										 |  |  | 		} else { | 
					
						
							| 
									
										
										
										
											2016-04-05 14:35:11 -04:00
										 |  |  | 			Log.log("Calendar received an unknown socket notification: " + notification); | 
					
						
							| 
									
										
										
										
											2016-03-31 11:05:32 +02:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		this.updateDom(this.config.animationSpeed); | 
					
						
							|  |  |  | 	}, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// Override dom generator.
 | 
					
						
							| 
									
										
										
										
											2016-10-14 15:23:03 +02:00
										 |  |  | 	getDom: function () { | 
					
						
							| 
									
										
										
										
											2016-03-31 11:05:32 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		var events = this.createEventList(); | 
					
						
							|  |  |  | 		var wrapper = document.createElement("table"); | 
					
						
							|  |  |  | 		wrapper.className = "small"; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if (events.length === 0) { | 
					
						
							| 
									
										
										
										
											2016-04-21 01:04:00 +02:00
										 |  |  | 			wrapper.innerHTML = (this.loaded) ? this.translate("EMPTY") : this.translate("LOADING"); | 
					
						
							| 
									
										
										
										
											2016-03-31 11:05:32 +02:00
										 |  |  | 			wrapper.className = "small dimmed"; | 
					
						
							|  |  |  | 			return wrapper; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		for (var e in events) { | 
					
						
							|  |  |  | 			var event = events[e]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			var eventWrapper = document.createElement("tr"); | 
					
						
							|  |  |  | 			eventWrapper.className = "normal"; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			if (this.config.displaySymbol) { | 
					
						
							| 
									
										
										
										
											2016-10-14 15:23:03 +02:00
										 |  |  | 				var symbolWrapper = document.createElement("td"); | 
					
						
							| 
									
										
										
										
											2016-03-31 11:05:32 +02:00
										 |  |  | 				symbolWrapper.className = "symbol"; | 
					
						
							| 
									
										
										
										
											2016-10-14 15:23:03 +02:00
										 |  |  | 				var symbol = document.createElement("span"); | 
					
						
							| 
									
										
										
										
											2016-03-31 11:05:32 +02:00
										 |  |  | 				symbol.className = "fa fa-" + this.symbolForUrl(event.url); | 
					
						
							|  |  |  | 				symbolWrapper.appendChild(symbol); | 
					
						
							|  |  |  | 				eventWrapper.appendChild(symbolWrapper); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-26 22:34:12 +02:00
										 |  |  | 			var titleWrapper = document.createElement("td"), | 
					
						
							| 
									
										
										
										
											2016-10-14 15:23:03 +02:00
										 |  |  | 				repeatingCountTitle = ""; | 
					
						
							| 
									
										
										
										
											2016-05-11 12:38:41 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			if (this.config.displayRepeatingCountTitle) { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-05-03 11:56:24 +02:00
										 |  |  | 				repeatingCountTitle = this.countTitleForUrl(event.url); | 
					
						
							| 
									
										
										
										
											2016-05-11 12:38:41 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-14 15:23:03 +02:00
										 |  |  | 				if (repeatingCountTitle !== "") { | 
					
						
							| 
									
										
										
										
											2016-04-26 22:34:12 +02:00
										 |  |  | 					var thisYear = new Date().getFullYear(), | 
					
						
							|  |  |  | 						yearDiff = thisYear - event.firstYear; | 
					
						
							| 
									
										
										
										
											2016-05-11 12:38:41 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-14 15:23:03 +02:00
										 |  |  | 					repeatingCountTitle = ", " + yearDiff + ". " + repeatingCountTitle; | 
					
						
							| 
									
										
										
										
											2016-04-26 22:34:12 +02:00
										 |  |  | 				} | 
					
						
							| 
									
										
										
										
											2016-05-11 12:38:41 +02:00
										 |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-26 22:34:12 +02:00
										 |  |  | 			titleWrapper.innerHTML = this.titleTransform(event.title) + repeatingCountTitle; | 
					
						
							| 
									
										
										
										
											2016-03-31 11:05:32 +02:00
										 |  |  | 			titleWrapper.className = "title bright"; | 
					
						
							|  |  |  | 			eventWrapper.appendChild(titleWrapper); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-14 15:23:03 +02:00
										 |  |  | 			var timeWrapper = document.createElement("td"); | 
					
						
							| 
									
										
										
										
											2016-04-15 12:50:34 +02:00
										 |  |  | 			//console.log(event.today);
 | 
					
						
							| 
									
										
										
										
											2016-04-20 21:40:56 +02:00
										 |  |  | 			var now = new Date(); | 
					
						
							| 
									
										
										
										
											2016-05-10 11:58:05 -06:00
										 |  |  | 			// Define second, minute, hour, and day variables
 | 
					
						
							| 
									
										
										
										
											2016-10-14 15:23:03 +02:00
										 |  |  | 			var oneSecond = 1000; // 1,000 milliseconds
 | 
					
						
							|  |  |  | 			var oneMinute = oneSecond * 60; | 
					
						
							|  |  |  | 			var oneHour = oneMinute * 60; | 
					
						
							|  |  |  | 			var oneDay = oneHour * 24; | 
					
						
							| 
									
										
										
										
											2016-04-15 12:50:34 +02:00
										 |  |  | 			if (event.fullDayEvent) { | 
					
						
							| 
									
										
										
										
											2016-04-20 21:40:56 +02:00
										 |  |  | 				if (event.today) { | 
					
						
							| 
									
										
										
										
											2016-09-03 00:39:46 +02:00
										 |  |  | 					timeWrapper.innerHTML = this.capFirst(this.translate("TODAY")); | 
					
						
							| 
									
										
										
										
											2016-10-14 15:23:03 +02:00
										 |  |  | 				} else if (event.startDate - now < oneDay && event.startDate - now > 0) { | 
					
						
							| 
									
										
										
										
											2016-09-03 00:39:46 +02:00
										 |  |  | 					timeWrapper.innerHTML = this.capFirst(this.translate("TOMORROW")); | 
					
						
							| 
									
										
										
										
											2016-10-14 15:23:03 +02:00
										 |  |  | 				} else if (event.startDate - now < 2 * oneDay && event.startDate - now > 0) { | 
					
						
							|  |  |  | 					if (this.translate("DAYAFTERTOMORROW") !== "DAYAFTERTOMORROW") { | 
					
						
							|  |  |  | 						timeWrapper.innerHTML = this.capFirst(this.translate("DAYAFTERTOMORROW")); | 
					
						
							| 
									
										
										
										
											2016-08-31 14:39:37 +02:00
										 |  |  | 					} else { | 
					
						
							| 
									
										
										
										
											2016-10-14 15:23:03 +02:00
										 |  |  | 						timeWrapper.innerHTML = this.capFirst(moment(event.startDate, "x").fromNow()); | 
					
						
							| 
									
										
										
										
											2016-08-31 14:39:37 +02:00
										 |  |  | 					} | 
					
						
							| 
									
										
										
										
											2016-04-20 21:40:56 +02:00
										 |  |  | 				} else { | 
					
						
							| 
									
										
										
										
											2016-05-10 11:58:05 -06:00
										 |  |  | 					/* Check to see if the user displays absolute or relative dates with their events | 
					
						
							|  |  |  | 					 * Also check to see if an event is happening within an 'urgency' time frameElement | 
					
						
							|  |  |  | 					 * For example, if the user set an .urgency of 7 days, those events that fall within that | 
					
						
							|  |  |  | 					 * time frame will be displayed with 'in xxx' time format or moment.fromNow() | 
					
						
							|  |  |  | 					 * | 
					
						
							|  |  |  | 					 * Note: this needs to be put in its own function, as the whole thing repeats again verbatim | 
					
						
							|  |  |  | 					 */ | 
					
						
							| 
									
										
										
										
											2016-05-10 01:01:00 -06:00
										 |  |  | 					if (this.config.timeFormat === "absolute") { | 
					
						
							| 
									
										
										
										
											2016-10-14 15:23:03 +02:00
										 |  |  | 						if ((this.config.urgency > 1) && (event.startDate - now < (this.config.urgency * oneDay))) { | 
					
						
							| 
									
										
										
										
											2016-05-10 11:58:05 -06:00
										 |  |  | 							// This event falls within the config.urgency period that the user has set
 | 
					
						
							| 
									
										
										
										
											2016-09-03 00:39:46 +02:00
										 |  |  | 							timeWrapper.innerHTML = this.capFirst(moment(event.startDate, "x").fromNow()); | 
					
						
							| 
									
										
										
										
											2016-05-10 01:01:00 -06:00
										 |  |  | 						} else { | 
					
						
							| 
									
										
										
										
											2016-11-10 17:26:29 +01:00
										 |  |  | 							timeWrapper.innerHTML = this.capFirst(moment(event.startDate, "x").format(this.config.dateFormat)); | 
					
						
							| 
									
										
										
										
											2016-05-10 01:01:00 -06:00
										 |  |  | 						} | 
					
						
							|  |  |  | 					} else { | 
					
						
							| 
									
										
										
										
											2016-10-14 15:23:03 +02:00
										 |  |  | 						timeWrapper.innerHTML = this.capFirst(moment(event.startDate, "x").fromNow()); | 
					
						
							| 
									
										
										
										
											2016-05-10 01:01:00 -06:00
										 |  |  | 					} | 
					
						
							| 
									
										
										
										
											2016-04-20 21:40:56 +02:00
										 |  |  | 				} | 
					
						
							| 
									
										
										
										
											2016-04-15 12:50:34 +02:00
										 |  |  | 			} else { | 
					
						
							| 
									
										
										
										
											2016-04-15 13:13:06 +02:00
										 |  |  | 				if (event.startDate >= new Date()) { | 
					
						
							| 
									
										
										
										
											2016-10-14 15:23:03 +02:00
										 |  |  | 					if (event.startDate - now < 2 * oneDay) { | 
					
						
							| 
									
										
										
										
											2016-05-10 01:01:00 -06:00
										 |  |  | 						// This event is within the next 48 hours (2 days)
 | 
					
						
							| 
									
										
										
										
											2016-10-14 15:23:03 +02:00
										 |  |  | 						if (event.startDate - now < this.config.getRelative * oneHour) { | 
					
						
							| 
									
										
										
										
											2016-05-10 11:58:05 -06:00
										 |  |  | 							// If event is within 6 hour, display 'in xxx' time format or moment.fromNow()
 | 
					
						
							| 
									
										
										
										
											2016-09-03 00:39:46 +02:00
										 |  |  | 							timeWrapper.innerHTML = this.capFirst(moment(event.startDate, "x").fromNow()); | 
					
						
							| 
									
										
										
										
											2016-05-10 01:01:00 -06:00
										 |  |  | 						} else { | 
					
						
							|  |  |  | 							// Otherwise just say 'Today/Tomorrow at such-n-such time'
 | 
					
						
							| 
									
										
										
										
											2016-09-03 00:39:46 +02:00
										 |  |  | 							timeWrapper.innerHTML = this.capFirst(moment(event.startDate, "x").calendar()); | 
					
						
							| 
									
										
										
										
											2016-05-10 01:01:00 -06:00
										 |  |  | 						} | 
					
						
							| 
									
										
										
										
											2016-04-19 10:34:14 +02:00
										 |  |  | 					} else { | 
					
						
							| 
									
										
										
										
											2016-05-10 11:58:05 -06:00
										 |  |  | 						/* Check to see if the user displays absolute or relative dates with their events | 
					
						
							|  |  |  | 						 * Also check to see if an event is happening within an 'urgency' time frameElement | 
					
						
							|  |  |  | 						 * For example, if the user set an .urgency of 7 days, those events that fall within that | 
					
						
							|  |  |  | 						 * time frame will be displayed with 'in xxx' time format or moment.fromNow() | 
					
						
							|  |  |  | 						 * | 
					
						
							|  |  |  | 						 * Note: this needs to be put in its own function, as the whole thing repeats again verbatim | 
					
						
							|  |  |  | 						 */ | 
					
						
							| 
									
										
										
										
											2016-05-10 01:01:00 -06:00
										 |  |  | 						if (this.config.timeFormat === "absolute") { | 
					
						
							| 
									
										
										
										
											2016-10-14 15:23:03 +02:00
										 |  |  | 							if ((this.config.urgency > 1) && (event.startDate - now < (this.config.urgency * oneDay))) { | 
					
						
							| 
									
										
										
										
											2016-05-10 11:58:05 -06:00
										 |  |  | 								// This event falls within the config.urgency period that the user has set
 | 
					
						
							| 
									
										
										
										
											2016-09-03 00:39:46 +02:00
										 |  |  | 								timeWrapper.innerHTML = this.capFirst(moment(event.startDate, "x").fromNow()); | 
					
						
							| 
									
										
										
										
											2016-05-10 01:01:00 -06:00
										 |  |  | 							} else { | 
					
						
							| 
									
										
										
										
											2016-11-10 17:26:29 +01:00
										 |  |  | 								timeWrapper.innerHTML = this.capFirst(moment(event.startDate, "x").format(this.config.dateFormat)); | 
					
						
							| 
									
										
										
										
											2016-05-10 01:01:00 -06:00
										 |  |  | 							} | 
					
						
							|  |  |  | 						} else { | 
					
						
							| 
									
										
										
										
											2016-09-03 00:39:46 +02:00
										 |  |  | 							timeWrapper.innerHTML = this.capFirst(moment(event.startDate, "x").fromNow()); | 
					
						
							| 
									
										
										
										
											2016-05-10 01:01:00 -06:00
										 |  |  | 						} | 
					
						
							| 
									
										
										
										
											2016-04-19 10:34:14 +02:00
										 |  |  | 					} | 
					
						
							| 
									
										
										
										
											2016-04-15 13:13:06 +02:00
										 |  |  | 				} else { | 
					
						
							| 
									
										
										
										
											2016-10-14 15:23:03 +02:00
										 |  |  | 					timeWrapper.innerHTML = this.capFirst(this.translate("RUNNING")) + " " + moment(event.endDate, "x").fromNow(true); | 
					
						
							| 
									
										
										
										
											2016-04-15 13:13:06 +02:00
										 |  |  | 				} | 
					
						
							| 
									
										
										
										
											2016-04-15 12:50:34 +02:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2016-04-23 17:40:44 +02:00
										 |  |  | 			//timeWrapper.innerHTML += ' - '+ moment(event.startDate,'x').format('lll');
 | 
					
						
							|  |  |  | 			//console.log(event);
 | 
					
						
							| 
									
										
										
										
											2016-03-31 11:05:32 +02:00
										 |  |  | 			timeWrapper.className = "time light"; | 
					
						
							|  |  |  | 			eventWrapper.appendChild(timeWrapper); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			wrapper.appendChild(eventWrapper); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			// Create fade effect.
 | 
					
						
							|  |  |  | 			if (this.config.fade && this.config.fadePoint < 1) { | 
					
						
							|  |  |  | 				if (this.config.fadePoint < 0) { | 
					
						
							|  |  |  | 					this.config.fadePoint = 0; | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 				var startingPoint = events.length * this.config.fadePoint; | 
					
						
							|  |  |  | 				var steps = events.length - startingPoint; | 
					
						
							|  |  |  | 				if (e >= startingPoint) { | 
					
						
							|  |  |  | 					var currentStep = e - startingPoint; | 
					
						
							|  |  |  | 					eventWrapper.style.opacity = 1 - (1 / steps * currentStep); | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		return wrapper; | 
					
						
							|  |  |  | 	}, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* hasCalendarURL(url) | 
					
						
							|  |  |  | 	 * Check if this config contains the calendar url. | 
					
						
							|  |  |  | 	 * | 
					
						
							|  |  |  | 	 * argument url sting - Url to look for. | 
					
						
							|  |  |  | 	 * | 
					
						
							|  |  |  | 	 * return bool - Has calendar url | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2016-10-14 15:23:03 +02:00
										 |  |  | 	hasCalendarURL: function (url) { | 
					
						
							| 
									
										
										
										
											2016-03-31 11:05:32 +02:00
										 |  |  | 		for (var c in this.config.calendars) { | 
					
						
							|  |  |  | 			var calendar = this.config.calendars[c]; | 
					
						
							|  |  |  | 			if (calendar.url === url) { | 
					
						
							|  |  |  | 				return true; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		return false; | 
					
						
							|  |  |  | 	}, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* createEventList() | 
					
						
							|  |  |  | 	 * Creates the sorted list of all events. | 
					
						
							|  |  |  | 	 * | 
					
						
							|  |  |  | 	 * return array - Array with events. | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2016-10-14 15:23:03 +02:00
										 |  |  | 	createEventList: function () { | 
					
						
							| 
									
										
										
										
											2016-03-31 11:05:32 +02:00
										 |  |  | 		var events = []; | 
					
						
							| 
									
										
										
										
											2016-04-05 14:35:11 -04:00
										 |  |  | 		var today = moment().startOf("day"); | 
					
						
							| 
									
										
										
										
											2016-03-31 11:05:32 +02:00
										 |  |  | 		for (var c in this.calendarData) { | 
					
						
							|  |  |  | 			var calendar = this.calendarData[c]; | 
					
						
							|  |  |  | 			for (var e in calendar) { | 
					
						
							|  |  |  | 				var event = calendar[e]; | 
					
						
							|  |  |  | 				event.url = c; | 
					
						
							| 
									
										
										
										
											2016-04-05 11:20:47 +02:00
										 |  |  | 				event.today = event.startDate >= today && event.startDate < (today + 24 * 60 * 60 * 1000); | 
					
						
							| 
									
										
										
										
											2016-03-31 11:05:32 +02:00
										 |  |  | 				events.push(event); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-14 15:23:03 +02:00
										 |  |  | 		events.sort(function (a, b) { | 
					
						
							| 
									
										
										
										
											2016-03-31 11:05:32 +02:00
										 |  |  | 			return a.startDate - b.startDate; | 
					
						
							|  |  |  | 		}); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		return events.slice(0, this.config.maximumEntries); | 
					
						
							|  |  |  | 	}, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* createEventList(url) | 
					
						
							|  |  |  | 	 * Requests node helper to add calendar url. | 
					
						
							|  |  |  | 	 * | 
					
						
							|  |  |  | 	 * argument url sting - Url to add. | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2016-10-14 15:23:03 +02:00
										 |  |  | 	addCalendar: function (url, user, pass) { | 
					
						
							| 
									
										
										
										
											2016-04-05 14:35:11 -04:00
										 |  |  | 		this.sendSocketNotification("ADD_CALENDAR", { | 
					
						
							| 
									
										
										
										
											2016-03-31 11:05:32 +02:00
										 |  |  | 			url: url, | 
					
						
							|  |  |  | 			maximumEntries: this.config.maximumEntries, | 
					
						
							| 
									
										
										
										
											2016-04-03 19:52:13 +02:00
										 |  |  | 			maximumNumberOfDays: this.config.maximumNumberOfDays, | 
					
						
							| 
									
										
										
										
											2016-09-08 17:36:30 +02:00
										 |  |  | 			fetchInterval: this.config.fetchInterval, | 
					
						
							|  |  |  | 			user: user, | 
					
						
							|  |  |  | 			pass: pass | 
					
						
							| 
									
										
										
										
											2016-03-31 11:05:32 +02:00
										 |  |  | 		}); | 
					
						
							|  |  |  | 	}, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* symbolForUrl(url) | 
					
						
							|  |  |  | 	 * Retrieves the symbol for a specific url. | 
					
						
							|  |  |  | 	 * | 
					
						
							|  |  |  | 	 * argument url sting - Url to look for. | 
					
						
							|  |  |  | 	 * | 
					
						
							|  |  |  | 	 * return string - The Symbol | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2016-10-14 15:23:03 +02:00
										 |  |  | 	symbolForUrl: function (url) { | 
					
						
							| 
									
										
										
										
											2016-03-31 11:05:32 +02:00
										 |  |  | 		for (var c in this.config.calendars) { | 
					
						
							|  |  |  | 			var calendar = this.config.calendars[c]; | 
					
						
							| 
									
										
										
										
											2016-10-14 15:23:03 +02:00
										 |  |  | 			if (calendar.url === url && typeof calendar.symbol === "string") { | 
					
						
							| 
									
										
										
										
											2016-03-31 11:05:32 +02:00
										 |  |  | 				return calendar.symbol; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		return this.config.defaultSymbol; | 
					
						
							|  |  |  | 	}, | 
					
						
							| 
									
										
										
										
											2016-04-26 22:34:12 +02:00
										 |  |  | 	/* countTitleForUrl(url) | 
					
						
							|  |  |  | 	 * Retrieves the name for a specific url. | 
					
						
							|  |  |  | 	 * | 
					
						
							|  |  |  | 	 * argument url sting - Url to look for. | 
					
						
							|  |  |  | 	 * | 
					
						
							|  |  |  | 	 * return string - The Symbol | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2016-10-14 15:23:03 +02:00
										 |  |  | 	countTitleForUrl: function (url) { | 
					
						
							| 
									
										
										
										
											2016-04-26 22:34:12 +02:00
										 |  |  | 		for (var c in this.config.calendars) { | 
					
						
							|  |  |  | 			var calendar = this.config.calendars[c]; | 
					
						
							| 
									
										
										
										
											2016-10-14 15:23:03 +02:00
										 |  |  | 			if (calendar.url === url && typeof calendar.repeatingCountTitle === "string") { | 
					
						
							| 
									
										
										
										
											2016-04-26 22:34:12 +02:00
										 |  |  | 				return calendar.repeatingCountTitle; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		return this.config.defaultRepeatingCountTitle; | 
					
						
							|  |  |  | 	}, | 
					
						
							| 
									
										
										
										
											2016-03-31 11:05:32 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* shorten(string, maxLength) | 
					
						
							|  |  |  | 	 * Shortens a sting if it's longer than maxLenthg. | 
					
						
							|  |  |  | 	 * Adds an ellipsis to the end. | 
					
						
							|  |  |  | 	 * | 
					
						
							|  |  |  | 	 * argument string string - The string to shorten. | 
					
						
							|  |  |  | 	 * argument maxLength number - The max lenth of the string. | 
					
						
							|  |  |  | 	 * | 
					
						
							|  |  |  | 	 * return string - The shortened string. | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2016-10-14 15:23:03 +02:00
										 |  |  | 	shorten: function (string, maxLength) { | 
					
						
							| 
									
										
										
										
											2016-03-31 11:05:32 +02:00
										 |  |  | 		if (string.length > maxLength) { | 
					
						
							| 
									
										
										
										
											2016-10-14 15:23:03 +02:00
										 |  |  | 			return string.slice(0, maxLength) + "…"; | 
					
						
							| 
									
										
										
										
											2016-03-31 11:05:32 +02:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		return string; | 
					
						
							|  |  |  | 	}, | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-03 00:39:46 +02:00
										 |  |  | 	/* capFirst(string) | 
					
						
							|  |  |  | 	 * Capitalize the first letter of a string | 
					
						
							|  |  |  | 	 * Eeturn capitalized string | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2016-10-14 15:23:03 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	capFirst: function (string) { | 
					
						
							| 
									
										
										
										
											2016-09-03 00:39:46 +02:00
										 |  |  | 		return string.charAt(0).toUpperCase() + string.slice(1); | 
					
						
							|  |  |  | 	}, | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-31 11:05:32 +02:00
										 |  |  | 	/* titleTransform(title) | 
					
						
							|  |  |  | 	 * Transforms the title of an event for usage. | 
					
						
							|  |  |  | 	 * Replaces parts of the text as defined in config.titleReplace. | 
					
						
							|  |  |  | 	 * Shortens title based on config.maxTitleLength | 
					
						
							|  |  |  | 	 * | 
					
						
							|  |  |  | 	 * argument title string - The title to transform. | 
					
						
							|  |  |  | 	 * | 
					
						
							|  |  |  | 	 * return string - The transformed title. | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2016-10-14 15:23:03 +02:00
										 |  |  | 	titleTransform: function (title) { | 
					
						
							| 
									
										
										
										
											2016-03-31 11:05:32 +02:00
										 |  |  | 		for (var needle in this.config.titleReplace) { | 
					
						
							|  |  |  | 			var replacement = this.config.titleReplace[needle]; | 
					
						
							|  |  |  | 			title = title.replace(needle, replacement); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		title = this.shorten(title, this.config.maxTitleLength); | 
					
						
							|  |  |  | 		return title; | 
					
						
							| 
									
										
										
										
											2016-10-14 15:23:03 +02:00
										 |  |  | 	}, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* broadcastEvents() | 
					
						
							|  |  |  | 	 * Broadcasts the events to all other modules for reuse. | 
					
						
							|  |  |  | 	 * The all events available in one array, sorted on startdate.  | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	broadcastEvents: function () { | 
					
						
							|  |  |  | 		var eventList = []; | 
					
						
							|  |  |  | 		for (url in this.calendarData) { | 
					
						
							|  |  |  | 			var calendar = this.calendarData[url]; | 
					
						
							|  |  |  | 			for (e in calendar) { | 
					
						
							|  |  |  | 				var event = cloneObject(calendar[e]); | 
					
						
							|  |  |  | 				delete event.url; | 
					
						
							|  |  |  | 				eventList.push(event); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		eventList.sort(function(a,b) { | 
					
						
							|  |  |  | 			return a.startDate - b.startDate; | 
					
						
							|  |  |  | 		}); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		this.sendNotification("CALENDAR_EVENTS", eventList); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-31 11:05:32 +02:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2016-04-03 19:52:13 +02:00
										 |  |  | }); |