From 2c07af8c69e636cf09d9975af76e7756ae7bae41 Mon Sep 17 00:00:00 2001 From: Justin Dalrymple Date: Tue, 25 Apr 2023 23:07:16 -0400 Subject: [PATCH] feat: add `wrapperTemplate` option (#348) --- .../__tests__/__snapshots__/index.js.snap | 26 +++++++++++++++++++ src/generate/__tests__/index.js | 13 ++++++++++ src/generate/index.js | 12 +++++++-- 3 files changed, 49 insertions(+), 2 deletions(-) diff --git a/src/generate/__tests__/__snapshots__/index.js.snap b/src/generate/__tests__/__snapshots__/index.js.snap index b8f576a..0786d91 100644 --- a/src/generate/__tests__/__snapshots__/index.js.snap +++ b/src/generate/__tests__/__snapshots__/index.js.snap @@ -1,5 +1,31 @@ // Jest Snapshot v1, https://goo.gl/fbAQLP +exports[`replace the content between the ALL-CONTRIBUTORS-LIST tags by a custom wrapper around the list of contributors contained in the "bodyContent" tag 1`] = ` +"# project + +Description + +## Contributors +These people contributed to the project: + + + +

+ + Kent C. Dodds is awesome! + Divjot Singh is awesome! + Jeroen Engels is awesome! + +

+ + + + + + +Thanks a lot everyone!" +`; + exports[`replace the content between the ALL-CONTRIBUTORS-LIST tags by a table of contributors 1`] = ` "# project diff --git a/src/generate/__tests__/index.js b/src/generate/__tests__/index.js index eeb285c..22d8833 100644 --- a/src/generate/__tests__/index.js +++ b/src/generate/__tests__/index.js @@ -69,6 +69,19 @@ test('replace the content between the ALL-CONTRIBUTORS-LIST tags by a table of c expect(result).toMatchSnapshot() }) +test('replace the content between the ALL-CONTRIBUTORS-LIST tags by a custom wrapper around the list of contributors contained in the "bodyContent" tag', () => { + const {kentcdodds, bogas04} = contributors + const {options, jfmengels, content} = fixtures() + const contributorList = [kentcdodds, bogas04, jfmengels] + const result = generate( + Object.assign(options, { wrapperTemplate: '

<%= bodyContent %>

'}), + contributorList, + content, + ) + + expect(result).toMatchSnapshot() +}) + test('split contributors into multiples lines when there are too many', () => { const {kentcdodds} = contributors const {options, content} = fixtures() diff --git a/src/generate/index.js b/src/generate/index.js index 11eaedb..033894e 100644 --- a/src/generate/index.js +++ b/src/generate/index.js @@ -66,6 +66,10 @@ function formatFooter(options) { function generateContributorsList(options, contributors) { const tableFooter = formatFooter(options) + const defaultWrapperTemplate = _.template('\n\n <%= bodyContent %> \n<%= tableFooterContent %>
\n\n') + const wrapperTemplate = options.wrapperTemplate ? _.template(`\n${options.wrapperTemplate}\n\n`) : defaultWrapperTemplate + const seperator = options.wrapperTemplate ? '\n
\n \n ' : '\n \n \n ' + let tableFooterContent = '' return _.flow( @@ -81,12 +85,15 @@ function generateContributorsList(options, contributors) { _.map((currentLineContributors) => formatLine( options, currentLineContributors )), - _.join('\n \n \n '), + _.join(seperator), newContent => { if (options.linkToUsage) { tableFooterContent = ` \n ${tableFooter}\n \n` } - return `\n\n \n \n ${newContent}\n \n \n${tableFooterContent}
\n\n` + + const bodyContent = `\n \n ${newContent}\n \n` + + return wrapperTemplate({ bodyContent, tableFooterContent}) }, )(contributors) } @@ -135,6 +142,7 @@ module.exports = function generate(options, contributors, fileContent) { ? '\n' : generateContributorsList(options, contributors) const badge = formatBadge(options, contributors) + return _.flow( injectListBetweenTags(contributorsList), replaceBadge(badge),