| 
									
										
										
										
											2022-01-26 23:09:26 +01:00
										 |  |  | /* MagicMirror² | 
					
						
							| 
									
										
										
										
											2020-06-01 16:40:20 +02:00
										 |  |  |  * Log | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2020-05-03 18:59:26 +02:00
										 |  |  |  * This logger is very simple, but needs to be extended. | 
					
						
							|  |  |  |  * This system can eventually be used to push the log messages to an external target. | 
					
						
							| 
									
										
										
										
											2016-03-24 17:19:32 +01:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2020-04-28 23:05:28 +02:00
										 |  |  |  * By Michael Teeuw https://michaelteeuw.nl
 | 
					
						
							| 
									
										
										
										
											2016-03-24 17:19:32 +01:00
										 |  |  |  * MIT Licensed. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2020-05-11 07:22:40 +02:00
										 |  |  | (function (root, factory) { | 
					
						
							| 
									
										
										
										
											2020-05-25 18:57:15 +02:00
										 |  |  | 	if (typeof exports === "object") { | 
					
						
							| 
									
										
										
										
											2021-09-13 23:55:41 +02:00
										 |  |  | 		if (process.env.JEST_WORKER_ID === undefined) { | 
					
						
							|  |  |  | 			// add timestamps in front of log messages
 | 
					
						
							|  |  |  | 			require("console-stamp")(console, { | 
					
						
							|  |  |  | 				pattern: "yyyy-mm-dd HH:MM:ss.l", | 
					
						
							|  |  |  | 				include: ["debug", "log", "info", "warn", "error"] | 
					
						
							|  |  |  | 			}); | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2020-05-11 07:22:40 +02:00
										 |  |  | 		// Node, CommonJS-like
 | 
					
						
							|  |  |  | 		module.exports = factory(root.config); | 
					
						
							|  |  |  | 	} else { | 
					
						
							|  |  |  | 		// Browser globals (root is window)
 | 
					
						
							|  |  |  | 		root.Log = factory(root.config); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2020-05-25 18:57:15 +02:00
										 |  |  | })(this, function (config) { | 
					
						
							| 
									
										
										
										
											2021-09-13 23:55:41 +02:00
										 |  |  | 	let logLevel; | 
					
						
							| 
									
										
										
										
											2021-09-24 21:30:51 +02:00
										 |  |  | 	let enableLog; | 
					
						
							|  |  |  | 	if (typeof exports === "object") { | 
					
						
							|  |  |  | 		// in nodejs and not running with jest
 | 
					
						
							| 
									
										
										
										
											2021-09-24 23:39:12 +02:00
										 |  |  | 		enableLog = process.env.JEST_WORKER_ID === undefined; | 
					
						
							| 
									
										
										
										
											2021-09-24 21:30:51 +02:00
										 |  |  | 	} else { | 
					
						
							|  |  |  | 		// in browser and not running with jsdom
 | 
					
						
							| 
									
										
										
										
											2021-09-28 22:08:21 +02:00
										 |  |  | 		enableLog = typeof window === "object" && window.name !== "jsdom"; | 
					
						
							| 
									
										
										
										
											2021-09-24 23:39:12 +02:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2021-09-24 21:30:51 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if (enableLog) { | 
					
						
							| 
									
										
										
										
											2021-09-13 23:55:41 +02:00
										 |  |  | 		logLevel = { | 
					
						
							| 
									
										
										
										
											2021-09-16 22:36:18 +02:00
										 |  |  | 			debug: Function.prototype.bind.call(console.debug, console), | 
					
						
							|  |  |  | 			log: Function.prototype.bind.call(console.log, console), | 
					
						
							|  |  |  | 			info: Function.prototype.bind.call(console.info, console), | 
					
						
							|  |  |  | 			warn: Function.prototype.bind.call(console.warn, console), | 
					
						
							|  |  |  | 			error: Function.prototype.bind.call(console.error, console), | 
					
						
							|  |  |  | 			group: Function.prototype.bind.call(console.group, console), | 
					
						
							|  |  |  | 			groupCollapsed: Function.prototype.bind.call(console.groupCollapsed, console), | 
					
						
							|  |  |  | 			groupEnd: Function.prototype.bind.call(console.groupEnd, console), | 
					
						
							|  |  |  | 			time: Function.prototype.bind.call(console.time, console), | 
					
						
							| 
									
										
										
										
											2021-09-24 21:30:51 +02:00
										 |  |  | 			timeEnd: Function.prototype.bind.call(console.timeEnd, console), | 
					
						
							|  |  |  | 			timeStamp: Function.prototype.bind.call(console.timeStamp, console) | 
					
						
							| 
									
										
										
										
											2021-09-16 22:36:18 +02:00
										 |  |  | 		}; | 
					
						
							| 
									
										
										
										
											2021-09-09 23:30:36 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-09-13 23:55:41 +02:00
										 |  |  | 		logLevel.setLogLevel = function (newLevel) { | 
					
						
							|  |  |  | 			if (newLevel) { | 
					
						
							|  |  |  | 				Object.keys(logLevel).forEach(function (key, index) { | 
					
						
							|  |  |  | 					if (!newLevel.includes(key.toLocaleUpperCase())) { | 
					
						
							|  |  |  | 						logLevel[key] = function () {}; | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 				}); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		}; | 
					
						
							|  |  |  | 	} else { | 
					
						
							|  |  |  | 		logLevel = { | 
					
						
							|  |  |  | 			debug: function () {}, | 
					
						
							|  |  |  | 			log: function () {}, | 
					
						
							|  |  |  | 			info: function () {}, | 
					
						
							|  |  |  | 			warn: function () {}, | 
					
						
							|  |  |  | 			error: function () {}, | 
					
						
							|  |  |  | 			group: function () {}, | 
					
						
							|  |  |  | 			groupCollapsed: function () {}, | 
					
						
							|  |  |  | 			groupEnd: function () {}, | 
					
						
							|  |  |  | 			time: function () {}, | 
					
						
							|  |  |  | 			timeEnd: function () {}, | 
					
						
							|  |  |  | 			timeStamp: function () {} | 
					
						
							|  |  |  | 		}; | 
					
						
							| 
									
										
										
										
											2020-05-11 07:46:56 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-09-13 23:55:41 +02:00
										 |  |  | 		logLevel.setLogLevel = function () {}; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2021-09-09 21:49:10 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-11 07:46:56 +02:00
										 |  |  | 	return logLevel; | 
					
						
							| 
									
										
										
										
											2020-05-25 18:57:15 +02:00
										 |  |  | }); |