mirror of
https://github.com/freeCodeCamp/freeCodeCamp.git
synced 2025-12-19 10:07:46 -05:00
52 lines
1.5 KiB
TypeScript
52 lines
1.5 KiB
TypeScript
import { unlink } from 'fs/promises';
|
|
import { prompt } from 'inquirer';
|
|
import { getProjectPath } from './helpers/get-project-info.js';
|
|
import { getFileName } from './helpers/get-file-name.js';
|
|
import {
|
|
deleteChallengeFromMeta,
|
|
updateTaskMarkdownFiles,
|
|
updateTaskMeta
|
|
} from './utils.js';
|
|
import { isTaskChallenge } from './helpers/task-helpers.js';
|
|
import { getMetaData } from './helpers/project-metadata.js';
|
|
|
|
const deleteTask = async () => {
|
|
const path = getProjectPath();
|
|
const challenges = getMetaData().challengeOrder;
|
|
|
|
const challengeToDelete = (await prompt({
|
|
name: 'id',
|
|
message: 'Which challenge should be deleted?',
|
|
type: 'list',
|
|
choices: challenges.map(({ id, title }) => ({
|
|
name: title,
|
|
value: id
|
|
}))
|
|
})) as { id: string };
|
|
|
|
const indexToDelete = challenges.findIndex(
|
|
({ id }) => id === challengeToDelete.id
|
|
);
|
|
|
|
const fileToDelete = await getFileName(challengeToDelete.id);
|
|
if (!fileToDelete) {
|
|
throw new Error(`File not found for challenge ${challengeToDelete.id}`);
|
|
}
|
|
|
|
await unlink(`${path}${fileToDelete}`);
|
|
console.log(`Finished deleting file: '${fileToDelete}'.`);
|
|
|
|
await deleteChallengeFromMeta(indexToDelete);
|
|
console.log(`Finished removing challenge from 'meta.json'.`);
|
|
|
|
if (isTaskChallenge(challenges[indexToDelete].title)) {
|
|
await updateTaskMeta();
|
|
console.log("Finished updating tasks in 'meta.json'.");
|
|
|
|
updateTaskMarkdownFiles();
|
|
console.log(`Finished updating task markdown files.`);
|
|
}
|
|
};
|
|
|
|
void deleteTask();
|