Skip to content

Commit

Permalink
feat(importer): confirm build tool package removal from user
Browse files Browse the repository at this point in the history
  • Loading branch information
malept committed Dec 30, 2016
1 parent cef743b commit 2795e29
Showing 1 changed file with 23 additions and 14 deletions.
37 changes: 23 additions & 14 deletions src/electron-forge-import.js
Original file line number Diff line number Diff line change
Expand Up @@ -80,27 +80,36 @@ const main = async () => {
packageJSON.devDependencies = packageJSON.devDependencies || {};

const keys = Object.keys(packageJSON.dependencies).concat(Object.keys(packageJSON.devDependencies));
const buildToolPackages = [
'electron-builder',
'electron-download',
'electron-installer-debian',
'electron-installer-dmg',
'electron-installer-flatpak',
'electron-installer-redhat',
'electron-osx-sign',
'electron-packager',
'electron-winstaller',
];
const buildToolPackages = {
'electron-builder': 'provides mostly equivalent functionality',
'electron-download': 'already uses this module as a transitive dependency',
'electron-installer-debian': 'already uses this module as a transitive dependency',
'electron-installer-dmg': 'already uses this module as a transitive dependency',
'electron-installer-flatpak': 'already uses this module as a transitive dependency',
'electron-installer-redhat': 'already uses this module as a transitive dependency',
'electron-osx-sign': 'already uses this module as a transitive dependency',
'electron-packager': 'already uses this module as a transitive dependency',
'electron-winstaller': 'already uses this module as a transitive dependency',
};

let electronName;
for (const key of keys) {
if (key === 'electron' || key === 'electron-prebuilt') {
delete packageJSON.dependencies[key];
delete packageJSON.devDependencies[key];
electronName = key;
} else if (buildToolPackages.includes(key)) {
delete packageJSON.dependencies[key];
delete packageJSON.devDependencies[key];
} else if (buildToolPackages[key]) {
const explanation = buildToolPackages[key];
const { shouldRemoveDependency } = await inquirer.createPromptModule()({
type: 'confirm',
name: 'shouldRemoveDependency',
message: `Do you want us to remove the "${key}" dependency in package.json? Electron Forge ${explanation}.`,
});

if (shouldRemoveDependency) {
delete packageJSON.dependencies[key];
delete packageJSON.devDependencies[key];
}
}
}

Expand Down

0 comments on commit 2795e29

Please sign in to comment.