| 
									
										
										
										
											2018-06-22 16:58:29 +01:00
										 |  |  | const { dirname } = require('canonical-path'); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-02 22:24:29 +01:00
										 |  |  | module.exports = function processPackages(collectPackageContentDocsProcessor) { | 
					
						
							| 
									
										
										
										
											2018-06-22 16:58:29 +01:00
										 |  |  |   return { | 
					
						
							| 
									
										
										
										
											2019-04-02 22:24:29 +01:00
										 |  |  |     $runAfter: ['processAliasDocs', 'collectPackageContentDocsProcessor'], | 
					
						
							|  |  |  |     $runBefore: ['rendering-docs', 'checkContentRules'], | 
					
						
							| 
									
										
										
										
											2018-06-22 16:58:29 +01:00
										 |  |  |     $process(docs) { | 
					
						
							| 
									
										
										
										
											2019-04-02 22:24:29 +01:00
										 |  |  |       const packageContentFiles = collectPackageContentDocsProcessor.packageContentFiles; | 
					
						
							| 
									
										
										
										
											2018-06-22 16:58:29 +01:00
										 |  |  |       const packageMap = {}; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       docs.forEach(doc => { | 
					
						
							|  |  |  |         if (doc.docType === 'module') { | 
					
						
							|  |  |  |           // Convert the doc type from "module" to "package"
 | 
					
						
							|  |  |  |           doc.docType = 'package'; | 
					
						
							|  |  |  |           // The name is actually the full id
 | 
					
						
							|  |  |  |           doc.name = `@angular/${doc.id}`; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           // Partition the exports into groups by type
 | 
					
						
							|  |  |  |           if (doc.exports) { | 
					
						
							| 
									
										
										
										
											2019-04-02 22:24:29 +01:00
										 |  |  |             const publicExports = doc.exports.filter(doc => !doc.privateExport); | 
					
						
							|  |  |  |             doc.ngmodules = publicExports.filter(doc => doc.docType === 'ngmodule').sort(byId); | 
					
						
							|  |  |  |             doc.classes = publicExports.filter(doc => doc.docType === 'class').sort(byId); | 
					
						
							|  |  |  |             doc.decorators = publicExports.filter(doc => doc.docType === 'decorator').sort(byId); | 
					
						
							|  |  |  |             doc.functions = publicExports.filter(doc => doc.docType === 'function').sort(byId); | 
					
						
							|  |  |  |             doc.structures = publicExports.filter(doc => doc.docType === 'enum' || doc.docType === 'interface').sort(byId); | 
					
						
							|  |  |  |             doc.directives = publicExports.filter(doc => doc.docType === 'directive').sort(byId); | 
					
						
							|  |  |  |             doc.pipes = publicExports.filter(doc => doc.docType === 'pipe').sort(byId); | 
					
						
							|  |  |  |             doc.types = publicExports.filter(doc => doc.docType === 'type-alias' || doc.docType === 'const').sort(byId); | 
					
						
							|  |  |  |             if (publicExports.every(doc => !!doc.deprecated)) { | 
					
						
							| 
									
										
										
										
											2018-09-17 17:37:18 +01:00
										 |  |  |               doc.deprecated = 'all exports of this entry point are deprecated.'; | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2018-06-22 16:58:29 +01:00
										 |  |  |           } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           // Copy over docs from the PACKAGE.md file that is used to document packages
 | 
					
						
							|  |  |  |           const readmeDoc = packageContentFiles[dirname(doc.fileInfo.filePath)]; | 
					
						
							|  |  |  |           if (readmeDoc) { | 
					
						
							|  |  |  |             doc.shortDescription = readmeDoc.shortDescription; | 
					
						
							|  |  |  |             doc.description = readmeDoc.description; | 
					
						
							|  |  |  |             doc.see = readmeDoc.see; | 
					
						
							|  |  |  |             doc.fileInfo = readmeDoc.fileInfo; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           // Compute the primary/secondary entry point relationships
 | 
					
						
							|  |  |  |           const packageParts = doc.id.split('/'); | 
					
						
							|  |  |  |           const primaryPackageName = packageParts[0]; | 
					
						
							|  |  |  |           doc.isPrimaryPackage = packageParts.length === 1; | 
					
						
							|  |  |  |           doc.packageInfo = packageMap[primaryPackageName] = packageMap[primaryPackageName] || { primary: undefined, secondary: [] }; | 
					
						
							|  |  |  |           if (doc.isPrimaryPackage) { | 
					
						
							|  |  |  |             doc.packageInfo.primary = doc; | 
					
						
							|  |  |  |           } else { | 
					
						
							|  |  |  |             doc.packageInfo.secondary.push(doc); | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-17 17:37:18 +01:00
										 |  |  |       // Update package deprecation status (compared to entry point status)
 | 
					
						
							|  |  |  |       Object.keys(packageMap).forEach(key => { | 
					
						
							|  |  |  |         const pkg = packageMap[key]; | 
					
						
							|  |  |  |         pkg.primary.packageDeprecated = pkg.primary.deprecated !== undefined && pkg.secondary.every(entryPoint => entryPoint.deprecated !== undefined); | 
					
						
							|  |  |  |       }); | 
					
						
							| 
									
										
										
										
											2018-06-22 16:58:29 +01:00
										 |  |  |     } | 
					
						
							|  |  |  |   }; | 
					
						
							|  |  |  | }; | 
					
						
							| 
									
										
										
										
											2018-09-21 09:08:58 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | function byId(a, b) { | 
					
						
							|  |  |  |   return a.id > b.id ? 1 : -1; | 
					
						
							|  |  |  | } |