2017-01-26 09:03:53 -05:00
|
|
|
var Package = require('dgeni').Package;
|
|
|
|
var jsdocPackage = require('dgeni-packages/jsdoc');
|
|
|
|
var linksPackage = require('../links-package');
|
|
|
|
var path = require('canonical-path');
|
|
|
|
var fs = require('fs');
|
|
|
|
|
|
|
|
// Define the dgeni package for generating the docs
|
|
|
|
module.exports = new Package('content', [jsdocPackage, linksPackage])
|
|
|
|
|
|
|
|
// Register the services and file readers
|
|
|
|
.factory(require('./readers/content'))
|
|
|
|
|
|
|
|
// Configure file reading
|
|
|
|
.config(function(readFilesProcessor, contentFileReader) {
|
|
|
|
readFilesProcessor.fileReaders.push(contentFileReader);
|
|
|
|
})
|
|
|
|
|
2017-02-02 03:19:20 -05:00
|
|
|
.config(function(parseTagsProcessor, getInjectables) {
|
|
|
|
parseTagsProcessor.tagDefinitions = parseTagsProcessor.tagDefinitions.concat(
|
|
|
|
getInjectables(requireFolder('./tag-defs')));
|
|
|
|
})
|
|
|
|
|
2017-01-26 09:03:53 -05:00
|
|
|
// Configure ids and paths
|
|
|
|
.config(function(computeIdsProcessor, computePathsProcessor) {
|
|
|
|
|
|
|
|
computeIdsProcessor.idTemplates.push({
|
|
|
|
docTypes: ['content'],
|
|
|
|
getId: function(doc) {
|
|
|
|
return doc.fileInfo
|
|
|
|
.relativePath
|
|
|
|
// path should be relative to `modules` folder
|
|
|
|
.replace(/.*\/?modules\//, '')
|
|
|
|
// path should not include `/docs/`
|
|
|
|
.replace(/\/docs\//, '/')
|
|
|
|
// path should not have a suffix
|
|
|
|
.replace(/\.\w*$/, '');
|
|
|
|
},
|
|
|
|
getAliases: function(doc) { return [doc.id]; }
|
|
|
|
});
|
|
|
|
});
|
2017-02-02 03:19:20 -05:00
|
|
|
|
|
|
|
function requireFolder(folderPath) {
|
|
|
|
const absolutePath = path.resolve(__dirname, folderPath);
|
|
|
|
return fs.readdirSync(absolutePath)
|
|
|
|
.filter(p => !/[._]spec\.js$/.test(p)) // ignore spec files
|
|
|
|
.map(p => require(path.resolve(absolutePath, p)));
|
|
|
|
}
|