Add badge/contributors list injection

This commit is contained in:
Jeroen Engels 2016-03-21 23:53:02 +01:00
parent a33ef2307f
commit 5662c9389d
7 changed files with 180 additions and 11 deletions

View file

@ -3,14 +3,7 @@
var _ = require('lodash/fp'); var _ = require('lodash/fp');
var formatBadge = require('./formatBadge'); var formatBadge = require('./formatBadge');
var formatContributor = require('./formatContributor'); var formatContributor = require('./formatContributor');
var injectContentBetween = require('../markdown').injectContentBetween;
function injectContentBetween(lines, content, startIndex, endIndex) {
return [].concat(
lines.slice(0, startIndex),
content,
lines.slice(endIndex)
);
}
function injectBetweenTags(tag, newContent) { function injectBetweenTags(tag, newContent) {
return function (previousContent) { return function (previousContent) {

36
lib/init/addBadge.test.js Normal file
View file

@ -0,0 +1,36 @@
import test from 'ava';
import {addBadge} from './initContent';
test('should insert badge under title', t => {
const content = [
'# project',
'',
'Description',
'',
'Foo bar'
].join('\n');
const expected = [
'# project',
'<!-- ALL-CONTRIBUTORS-BADGE:START - Do not remove or modify this section --><!-- ALL-CONTRIBUTORS-BADGE:END -->',
'',
'Description',
'',
'Foo bar'
].join('\n');
const result = addBadge(content);
t.is(result, expected);
});
test('should add badge if content is empty', t => {
const content = '';
const expected = [
'',
'<!-- ALL-CONTRIBUTORS-BADGE:START - Do not remove or modify this section --><!-- ALL-CONTRIBUTORS-BADGE:END -->'
].join('\n');
const result = addBadge(content);
t.is(result, expected);
});

View file

@ -0,0 +1,60 @@
import test from 'ava';
import {addContributorsList} from './initContent';
test('should insert list under contributors section', t => {
const content = [
'# project',
'',
'Description',
'',
'## Contributors',
''
].join('\n');
const expected = [
'# project',
'',
'Description',
'',
'## Contributors',
'',
'<!-- ALL-CONTRIBUTORS-LIST:START - Do not remove or modify this section --><!-- ALL-CONTRIBUTORS-LIST:END -->'
].join('\n');
const result = addContributorsList(content);
t.is(result, expected);
});
test('should create contributors section if it is absent', t => {
const content = [
'# project',
'',
'Description'
].join('\n');
const expected = [
'# project',
'',
'Description',
'## Contributors',
'',
'<!-- ALL-CONTRIBUTORS-LIST:START - Do not remove or modify this section --><!-- ALL-CONTRIBUTORS-LIST:END -->'
].join('\n');
const result = addContributorsList(content);
t.is(result, expected);
});
test('should create contributors section if content is empty', t => {
const content = '';
const expected = [
'',
'## Contributors',
'',
'<!-- ALL-CONTRIBUTORS-LIST:START - Do not remove or modify this section --><!-- ALL-CONTRIBUTORS-LIST:END -->'
].join('\n');
const result = addContributorsList(content);
t.is(result, expected);
});

View file

@ -1,10 +1,35 @@
'use strict'; 'use strict';
var _ = require('lodash/fp');
var series = require('async/series');
var prompt = require('./prompt'); var prompt = require('./prompt');
var configFile = require('../configFile'); var configFile = require('../configFile');
var markdown = require('../markdown');
var initContent = require('./initContent');
module.exports = function init(cb) { function injectInFile(file, fn, cb) {
markdown.read(file, function (error, content) {
if (error) {
return cb(error);
}
markdown.write(file, fn(content), cb);
});
}
module.exports = function init(callback) {
prompt(function postPrompt(result) { prompt(function postPrompt(result) {
configFile.writeConfig('.all-contributorsrc', result.config, cb); var tasks = [
function writeConfig(cb) {
configFile.writeConfig('.all-contributorsrc', result.config, cb);
},
function addContributorsList(cb) {
injectInFile(result.contributorFile, initContent.addContributorsList, cb);
},
result.badgeFile && function addBadge(cb) {
injectInFile(result.badgeFile, initContent.addBadge, cb);
}
];
series(_.compact(tasks), callback);
}); });
}; };

45
lib/init/initContent.js Normal file
View file

@ -0,0 +1,45 @@
'use strict';
var _ = require('lodash/fp');
var injectContentBetween = require('../markdown').injectContentBetween;
function newContent(type) {
return '<!-- ALL-CONTRIBUTORS-' + type + ':START - Do not remove or modify this section --><!-- ALL-CONTRIBUTORS-' + type + ':END -->';
}
function addBadge(lines) {
return injectContentBetween(lines, newContent('BADGE'), 1, 1);
}
function splitAndRejoin(fn) {
return _.flow(
_.split('\n'),
fn,
_.join('\n')
);
}
var findContributorsSection = _.findIndex(function isContributorsSection(str) {
return str
.toLowerCase()
.indexOf('# contributors') === 1;
});
function addContributorsList(lines) {
var toInject = newContent('LIST');
var insertionLine = findContributorsSection(lines);
if (insertionLine === -1) {
return lines
.concat([
'## Contributors',
'',
toInject
]);
}
return injectContentBetween(lines, toInject, insertionLine + 2, insertionLine + 2);
}
module.exports = {
addBadge: splitAndRejoin(addBadge),
addContributorsList: splitAndRejoin(addContributorsList)
};

View file

@ -10,7 +10,16 @@ function write(filePath, content, cb) {
fs.writeFile(filePath, content, cb); fs.writeFile(filePath, content, cb);
} }
function injectContentBetween(lines, content, startIndex, endIndex) {
return [].concat(
lines.slice(0, startIndex),
content,
lines.slice(endIndex)
);
}
module.exports = { module.exports = {
read: read, read: read,
write: write write: write,
injectContentBetween: injectContentBetween
}; };

View file

@ -26,6 +26,7 @@
}, },
"homepage": "https://github.com/jfmengels/all-contributors-cli#readme", "homepage": "https://github.com/jfmengels/all-contributors-cli#readme",
"dependencies": { "dependencies": {
"async": "^2.0.0-rc.1",
"inquirer": "^0.12.0", "inquirer": "^0.12.0",
"lodash": "^4.6.1", "lodash": "^4.6.1",
"request": "^2.69.0", "request": "^2.69.0",