types-installer
Version:
Installs @types for your existing dependencies
260 lines • 27.1 kB
JavaScript
;
var __assign = (this && this.__assign) || function () {
__assign = Object.assign || function(t) {
for (var s, i = 1, n = arguments.length; i < n; i++) {
s = arguments[i];
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
t[p] = s[p];
}
return t;
};
return __assign.apply(this, arguments);
};
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
return new (P || (P = Promise))(function (resolve, reject) {
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); }
step((generator = generator.apply(thisArg, _arguments || [])).next());
});
};
var __generator = (this && this.__generator) || function (thisArg, body) {
var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
function verb(n) { return function (v) { return step([n, v]); }; }
function step(op) {
if (f) throw new TypeError("Generator is already executing.");
while (_) try {
if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
if (y = 0, t) op = [op[0] & 2, t.value];
switch (op[0]) {
case 0: case 1: t = op; break;
case 4: _.label++; return { value: op[1], done: false };
case 5: _.label++; y = op[1]; op = [0]; continue;
case 7: op = _.ops.pop(); _.trys.pop(); continue;
default:
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
if (t[2]) _.ops.pop();
_.trys.pop(); continue;
}
op = body.call(thisArg, _);
} catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
}
};
var _this = this;
Object.defineProperty(exports, "__esModule", { value: true });
var Bluebird = require("bluebird");
var c = require("chalk");
var execa_1 = require("execa");
var inquirer = require("inquirer");
var path_1 = require("path");
function getDependencies(_a) {
var _b = _a === void 0 ? {} : _a, _c = _b.selection, selection = _c === void 0 ? 'all' : _c, packageJson = _b.packageJson;
packageJson = packageJson || require(path_1.join(process.cwd(), 'package.json'));
var selections = {
dependencies: packageJson.dependencies || {},
devDependencies: packageJson.devDependencies || {},
all: __assign({}, packageJson.devDependencies || {}, packageJson.dependencies || {}),
};
var selected = selections[selection];
var keys = Object.keys(selected)
.filter(function (key) { return !/^@types\//.test(key); });
return { keys: keys, selected: selected, selections: selections };
}
exports.getDependencies = getDependencies;
function getYarnVersion() {
return __awaiter(this, void 0, void 0, function () {
var result, ex_1;
return __generator(this, function (_a) {
switch (_a.label) {
case 0:
_a.trys.push([0, 2, , 3]);
return [4 /*yield*/, execa_1.shell('yarn --version')];
case 1:
result = _a.sent();
return [2 /*return*/, result.stdout];
case 2:
ex_1 = _a.sent();
return [2 /*return*/, ''];
case 3: return [2 /*return*/];
}
});
});
}
/** @mything/banana becomes mything__banana */
var normalizeName = function (name) {
return /^@/.test(name)
? name.slice(1).split('/').join('__')
: name;
};
var getTypeDepName = function (name) { return "@types/" + normalizeName(name); };
function installTypes(dependencies, _a) {
var selections = _a.selections, _b = _a.toDev, toDev = _b === void 0 ? false : _b, _c = _a.pwd, pwd = _c === void 0 ? '' : _c, _d = _a.concurrency, concurrency = _d === void 0 ? 1 : _d, packageManager = _a.packageManager;
return __awaiter(this, void 0, void 0, function () {
var installCommand, directory, installs;
var _this = this;
return __generator(this, function (_e) {
switch (_e.label) {
case 0: return [4 /*yield*/, (function () { return __awaiter(_this, void 0, void 0, function () {
var _a;
return __generator(this, function (_b) {
switch (_b.label) {
case 0:
if (packageManager === 'pnpm') {
return [2 /*return*/, 'pnpm install'];
}
_a = packageManager;
if (_a) return [3 /*break*/, 2];
return [4 /*yield*/, getYarnVersion()];
case 1:
_a = ((_b.sent()) ? 'yarn' : 'npm');
_b.label = 2;
case 2:
packageManager = _a;
if (packageManager === 'yarn') {
return [2 /*return*/, 'yarn add'];
}
return [2 /*return*/, 'npm install'];
}
});
}); })()];
case 1:
installCommand = _e.sent();
directory = pwd ? "cd " + pwd + " &&" : '';
return [4 /*yield*/, Bluebird.map(dependencies, function (actualName) { return __awaiter(_this, void 0, void 0, function () {
var typeDep, saveTo, stdout, err_1;
return __generator(this, function (_a) {
switch (_a.label) {
case 0:
typeDep = getTypeDepName(actualName);
saveTo = toDev || (actualName in selections.devDependencies) ? '--dev' : '';
_a.label = 1;
case 1:
_a.trys.push([1, 3, , 4]);
return [4 /*yield*/, execa_1.shell(directory + " " + installCommand + " " + saveTo + " " + typeDep, {
env: __assign({}, process.env, { FORCE_COLOR: true }),
})];
case 2:
stdout = (_a.sent()).stdout;
console.log(c.green(typeDep), 'found');
console.log('\n', stdout, '\n');
return [3 /*break*/, 4];
case 3:
err_1 = _a.sent();
console.log(c.yellow(typeDep), 'not found or failed to install');
if (process.env.DEBUG) {
console.error(c.red(err_1));
}
return [3 /*break*/, 4];
case 4: return [2 /*return*/];
}
});
}); }, { concurrency: concurrency })];
case 2:
installs = _e.sent();
return [2 /*return*/, installs];
}
});
});
}
exports.installTypes = installTypes;
exports.install = function (_a) {
var _b = _a === void 0 ? {} : _a, _c = _b.selection, selection = _c === void 0 ? 'all' : _c, _d = _b.toDev, toDev = _d === void 0 ? false : _d, _e = _b.deps, deps = _e === void 0 ? '' : _e;
return __awaiter(_this, void 0, void 0, function () {
var results, selections, keys;
return __generator(this, function (_f) {
switch (_f.label) {
case 0:
if (deps) {
console.log("Installing dependency " + c.cyan.bold(deps || selection) + " in @types");
}
else {
console.log("Installing " + c.cyan.bold(selection) + " in @types");
}
results = getDependencies({ selection: selection });
selections = results.selections;
keys = results.keys;
if (deps) {
keys = keys.filter(function (key) { return key === deps; });
}
if (!keys.length) {
console.error(c.yellow('No dependencies to install'));
return [2 /*return*/];
}
return [4 /*yield*/, installTypes(keys, { toDev: toDev, selections: selections })];
case 1:
_f.sent();
return [2 /*return*/];
}
});
});
};
exports.interactiveInstall = function () { return __awaiter(_this, void 0, void 0, function () {
var _a, selection, toDev, packageManager, _b, keys, selections, selectedKeys;
return __generator(this, function (_c) {
switch (_c.label) {
case 0: return [4 /*yield*/, inquirer.prompt([
{
type: 'list',
name: 'selection',
message: "Install options:",
default: 0,
choices: [
'all',
'dependencies',
'devDependencies',
],
},
{
type: 'confirm',
name: 'toDev',
message: "Install all @types/* to " + c.cyan('devDependencies') + "?",
default: false,
},
{
type: 'list',
name: 'packageManager',
message: "Which package manager?:",
default: 'yarn',
choices: ['yarn', 'npm', 'pnpm'],
},
])];
case 1:
_a = _c.sent(), selection = _a.selection, toDev = _a.toDev, packageManager = _a.packageManager;
_b = getDependencies({ selection: selection }), keys = _b.keys, selections = _b.selections;
if (!keys.length) {
console.error(c.yellow('No dependencies to install'));
return [2 /*return*/];
}
console.log("Installing " + c.cyan.bold(selection) + " @type dependencies...");
console.log();
return [4 /*yield*/, inquirer.prompt([
{
type: 'checkbox',
name: 'selectedKeys',
message: 'select',
choices: keys.map(function (depName) {
var typeDep = getTypeDepName(depName);
var isAlreadyTyped = typeDep in selections.all;
return {
name: depName + " " + (isAlreadyTyped ? c.grey("(Installed: " + typeDep + ")") : ''),
value: depName,
checked: true,
};
}),
},
])];
case 2:
selectedKeys = (_c.sent()).selectedKeys;
return [4 /*yield*/, installTypes(selectedKeys, { toDev: toDev, selections: selections, packageManager: packageManager })];
case 3:
_c.sent();
return [2 /*return*/];
}
});
}); };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"actions.js","sourceRoot":"","sources":["../src/actions.ts"],"names":[],"mappings":"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","sourcesContent":["import * as Bluebird from 'bluebird';\nimport * as c from 'chalk';\nimport { shell } from 'execa';\nimport * as inquirer from 'inquirer';\nimport { join } from 'path';\n\n// tslint:disable:no-console\n\nexport interface IDependencies { [key: string]: string; }\nexport interface ISelections {\n  dependencies: IDependencies;\n  devDependencies: IDependencies;\n  all: IDependencies;\n}\n\nexport function getDependencies (\n  { selection = 'all', packageJson }: {\n    selection?: keyof ISelections,\n    packageJson?: any,\n  } = {}) {\n  packageJson = packageJson || require(join(process.cwd(), 'package.json'));\n\n  const selections: ISelections = {\n    dependencies: packageJson.dependencies || {},\n    devDependencies: packageJson.devDependencies || {},\n    all: {\n      ...packageJson.devDependencies || {},\n      ...packageJson.dependencies || {},\n    },\n  };\n\n  const selected = selections[selection];\n\n  const keys = Object.keys(selected)\n    .filter((key) => !/^@types\\//.test(key));\n\n  return { keys, selected, selections };\n}\n\nasync function getYarnVersion () {\n  try {\n    const result = await shell('yarn --version');\n    return result.stdout;\n  } catch (ex) {\n    return '';\n  }\n}\n\nexport interface IInstallOptions {\n  toDev?: boolean;\n  selection?: keyof ISelections;\n  packageManager?: 'npm' | 'yarn' | 'pnpm';\n  deps?: string;\n}\n\nexport interface IInstallTypesOptions extends IInstallOptions {\n  selections: ISelections;\n  pwd?: string;\n  concurrency?: number;\n}\n\n/** @mything/banana becomes mything__banana */\nconst normalizeName = (name: string) =>\n  /^@/.test(name)\n    ? name.slice(1).split('/').join('__')\n    : name;\n\nconst getTypeDepName = (name: string) => `@types/${normalizeName(name)}`;\n\nexport async function installTypes (\n  dependencies: string[],\n  { selections, toDev = false, pwd = '', concurrency = 1, packageManager }: IInstallTypesOptions,\n) {\n\n  const installCommand = await (async () => {\n    if (packageManager === 'pnpm') { return 'pnpm install'; }\n\n    packageManager = packageManager || (await getYarnVersion() ? 'yarn' : 'npm');\n\n    if (packageManager === 'yarn') { return 'yarn add'; }\n\n    return 'npm install';\n  })();\n\n  const directory = pwd ? `cd ${pwd} &&` : '';\n\n  const installs = await Bluebird.map(dependencies, async (actualName) => {\n    const typeDep = getTypeDepName(actualName);\n    const saveTo = toDev || (actualName in selections.devDependencies) ? '--dev' : '';\n\n    try {\n      const { stdout } = await shell(`${directory} ${installCommand} ${saveTo} ${typeDep}`, {\n        env: { ...process.env, FORCE_COLOR: true },\n      });\n\n      console.log(c.green(typeDep), 'found');\n      console.log('\\n', stdout, '\\n');\n    } catch (err) {\n      console.log(c.yellow(typeDep), 'not found or failed to install');\n      if (process.env.DEBUG) { console.error(c.red(err)); }\n    }\n  }, { concurrency });\n\n  return installs;\n}\n\nexport const install = async ({ selection = 'all', toDev = false, deps = '' }: IInstallOptions = {}) => {\n  if (deps) {\n    console.log(`Installing dependency ${c.cyan.bold(deps || selection)} in @types`);\n  } else {\n    console.log(`Installing ${c.cyan.bold(selection)} in @types`);\n  }\n\n  const results = getDependencies({ selection });\n  const { selections } = results;\n  let { keys } = results;\n\n  if (deps) {\n    keys = keys.filter((key) => key === deps);\n  }\n\n  if (!keys.length) {\n    console.error(c.yellow('No dependencies to install'));\n    return;\n  }\n\n  await installTypes(keys, { toDev, selections });\n};\n\nexport const interactiveInstall = async () => {\n  const { selection, toDev, packageManager } = await inquirer.prompt([\n    {\n      type: 'list',\n      name: 'selection',\n      message: `Install options:`,\n      default: 0,\n      choices: [\n        'all',\n        'dependencies',\n        'devDependencies',\n      ],\n    },\n    {\n      type: 'confirm',\n      name: 'toDev',\n      message: `Install all @types/* to ${c.cyan('devDependencies')}?`,\n      default: false,\n    },\n    {\n      type: 'list',\n      name: 'packageManager',\n      message: `Which package manager?:`,\n      default: 'yarn',\n      choices: ['yarn', 'npm', 'pnpm'] as Array<Required<IInstallOptions>['packageManager']>,\n    },\n  ]);\n\n  const { keys, selections } = getDependencies({ selection });\n\n  if (!keys.length) {\n    console.error(c.yellow('No dependencies to install'));\n    return;\n  }\n\n  console.log(`Installing ${c.cyan.bold(selection)} @type dependencies...`);\n  console.log();\n\n  const { selectedKeys } = await inquirer.prompt([\n    {\n      type: 'checkbox',\n      name: 'selectedKeys',\n      message: 'select',\n      choices: keys.map((depName) => {\n        const typeDep = getTypeDepName(depName);\n        const isAlreadyTyped = typeDep in selections.all;\n\n        return {\n          name: `${depName} ${isAlreadyTyped ? c.grey(`(Installed: ${typeDep})`) : ''}`,\n          value: depName,\n          checked: true,\n        };\n      }),\n    },\n  ]);\n\n  await installTypes(selectedKeys, { toDev, selections, packageManager });\n};\n"]}