Files
freeCodeCamp/tools/contributor/lib/pr-tasks/labeler.js
Oliver Eyton-Williams c8d7f0a782 feat(tools): remove eslint-plugin-prettier for prettier (#42438)
* feat: remove eslint-plugin-prettier for prettier

This removes the annoying lint warnings when all that needs to change is
formatting

* fix: use .js lint-staged config to ignore properly

* fix: lint everything if a lot of files are changed

It's faster than making lots of individual linter calls

* chore: apply prettier

* fix: ignore code in curriculum-file-structure
2021-10-06 21:02:21 +05:30

48 lines
1.6 KiB
JavaScript

const config = require('../../lib/config');
const { validLabels } = require('../validation');
const { addLabels } = require('./add-labels');
const { rateLimiter } = require('../utils');
const labeler = async (number, prFiles, currentLabels) => {
// holds potential labels to add based on file path
const labelsToAdd = {};
const existingLabels = currentLabels.map(({ name }) => name);
prFiles.forEach(({ filename }) => {
/* remove '/challenges' from filename so
language variable hold the language */
const filenameReplacement = filename.replace(
/^curriculum\/challenges\//,
'curriculum/'
);
const regex =
/^(docs|curriculum)(?:\/)(english|arabic|chinese|portuguese|russian|spanish)?\/?/;
// need an array to pass to labelsAdder
const match = filenameReplacement.match(regex) || [];
const articleType = match[1];
const language = match[2];
if (articleType && validLabels[articleType]) {
labelsToAdd[validLabels[articleType]] = 1;
}
if (language && validLabels[language]) {
labelsToAdd[validLabels[language]] = 1;
}
if (articleType === 'curriculum') {
labelsToAdd['status: need to test locally'] = 1;
}
});
// only adds needed labels which are NOT currently on the PR
const newLabels = Object.keys(labelsToAdd).filter((label) => {
return !existingLabels.includes(label);
});
if (newLabels.length) {
if (config.oneoff.productionRun) {
addLabels(number, newLabels);
await rateLimiter(1000);
}
}
return newLabels;
};
module.exports = { labeler };