| 
									
										
										
										
											2016-05-03 14:06:32 +02:00
										 |  |  | import { Injectable } from '@angular/core'; | 
					
						
							| 
									
										
										
										
											2015-11-21 11:23:40 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  | @Injectable() | 
					
						
							|  |  |  | export class LoggerService { | 
					
						
							| 
									
										
										
										
											2016-04-27 11:28:22 -07:00
										 |  |  |   logs: string[] = []; | 
					
						
							| 
									
										
										
										
											2016-01-23 18:21:09 +00:00
										 |  |  |   prevMsg = ''; | 
					
						
							|  |  |  |   prevMsgCount = 1; | 
					
						
							| 
									
										
										
										
											2015-11-21 11:23:40 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-27 11:28:22 -07:00
										 |  |  |   log(msg: string)  { | 
					
						
							| 
									
										
										
										
											2016-01-23 18:21:09 +00:00
										 |  |  |     if (msg === this.prevMsg) { | 
					
						
							|  |  |  |       // Repeat message; update last log entry with count.
 | 
					
						
							| 
									
										
										
										
											2016-04-27 11:28:22 -07:00
										 |  |  |       this.logs[this.logs.length - 1] = msg + ` (${this.prevMsgCount += 1}x)`; | 
					
						
							| 
									
										
										
										
											2016-01-23 18:21:09 +00:00
										 |  |  |     } else { | 
					
						
							|  |  |  |       // New message; log it.
 | 
					
						
							|  |  |  |       this.prevMsg = msg; | 
					
						
							|  |  |  |       this.prevMsgCount = 1; | 
					
						
							|  |  |  |       this.logs.push(msg); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-11-21 11:23:40 -08:00
										 |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-27 11:28:22 -07:00
										 |  |  |   clear() { this.logs.length = 0; } | 
					
						
							| 
									
										
										
										
											2015-11-21 11:23:40 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-23 18:21:09 +00:00
										 |  |  |   // schedules a view refresh to ensure display catches up
 | 
					
						
							| 
									
										
										
										
											2016-05-06 06:17:34 -07:00
										 |  |  |   tick() {  this.tick_then(() => { }); } | 
					
						
							|  |  |  |   tick_then(fn: () => any) { setTimeout(fn, 0); } | 
					
						
							| 
									
										
										
										
											2015-11-21 11:23:40 -08:00
										 |  |  | } |