| 
									
										
										
										
											2020-03-20 06:59:35 -07:00
										 |  |  | /** | 
					
						
							|  |  |  |  * @license | 
					
						
							|  |  |  |  * Copyright Google Inc. All Rights Reserved. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Use of this source code is governed by an MIT-style license that can be | 
					
						
							|  |  |  |  * found in the LICENSE file at https://angular.io/license
 | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2020-04-16 20:12:25 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-20 06:59:35 -07:00
										 |  |  | import {PullApproveGroupResult} from './group'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** Create logs for each pullapprove group result. */ | 
					
						
							|  |  |  | export function logGroup(group: PullApproveGroupResult, matched = true) { | 
					
						
							| 
									
										
										
										
											2020-04-16 20:12:25 +02:00
										 |  |  |   const conditions = matched ? group.matchedConditions : group.unmatchedConditions; | 
					
						
							| 
									
										
										
										
											2020-03-20 06:59:35 -07:00
										 |  |  |   console.groupCollapsed(`[${group.groupName}]`); | 
					
						
							| 
									
										
										
										
											2020-04-16 20:12:25 +02:00
										 |  |  |   if (conditions.length) { | 
					
						
							|  |  |  |     conditions.forEach(matcher => { | 
					
						
							|  |  |  |       const count = matcher.matchedFiles.size; | 
					
						
							|  |  |  |       console.info(`${count} ${count === 1 ? 'match' : 'matches'} - ${matcher.expression}`) | 
					
						
							|  |  |  |     }); | 
					
						
							| 
									
										
										
										
											2020-03-20 06:59:35 -07:00
										 |  |  |     console.groupEnd(); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** Logs a header within a text drawn box. */ | 
					
						
							|  |  |  | export function logHeader(...params: string[]) { | 
					
						
							|  |  |  |   const totalWidth = 80; | 
					
						
							|  |  |  |   const fillWidth = totalWidth - 2; | 
					
						
							|  |  |  |   const headerText = params.join(' ').substr(0, fillWidth); | 
					
						
							|  |  |  |   const leftSpace = Math.ceil((fillWidth - headerText.length) / 2); | 
					
						
							|  |  |  |   const rightSpace = fillWidth - leftSpace - headerText.length; | 
					
						
							|  |  |  |   const fill = (count: number, content: string) => content.repeat(count); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   console.info(`┌${fill(fillWidth, '─')}┐`); | 
					
						
							|  |  |  |   console.info(`│${fill(leftSpace, ' ')}${headerText}${fill(rightSpace, ' ')}│`); | 
					
						
							|  |  |  |   console.info(`└${fill(fillWidth, '─')}┘`); | 
					
						
							| 
									
										
										
										
											2020-04-16 20:12:25 +02:00
										 |  |  | } |