Browse Source

add progress spinner

master
Feross Aboukhadijeh 7 years ago
parent
commit
7a5070173d
  1. 21
      cmd.js
  2. 1
      package.json

21
cmd.js

@ -19,6 +19,10 @@ const DOWNLOADS_URL_LIMIT = 128
const readPackageTreeAsync = pify(readPackageTree) const readPackageTreeAsync = pify(readPackageTree)
init().catch(handleError) init().catch(handleError)
const spinner = ora({
spinner: 'moon',
text: chalk`Getting ready to {cyan give thanks} to {magenta maintainers}...`
}).start()
async function init () { async function init () {
const client = createRegistryClient() const client = createRegistryClient()
@ -27,17 +31,21 @@ async function init () {
const cwd = argv._[0] || process.cwd() const cwd = argv._[0] || process.cwd()
// Get all packages in the nearest `node_modules` folder // Get all packages in the nearest `node_modules` folder
spinner.text = chalk`Reading {cyan dependencies} from package tree in {magenta node_modules}...`
const rootPath = await pkgDir(cwd) const rootPath = await pkgDir(cwd)
const packageTree = await readPackageTreeAsync(rootPath) const packageTree = await readPackageTreeAsync(rootPath)
// Get latest registry data on each local package, since the local data does // Get latest registry data on each local package, since the local data does
// not include the list of maintainers // not include the list of maintainers
spinner.text = chalk`Fetching package {cyan maintainers} from {red npm}...`
const pkgNames = packageTree.children.map(node => node.package.name) const pkgNames = packageTree.children.map(node => node.package.name)
const allPkgs = await Promise.all(pkgNames.map(fetchPkg)) const allPkgs = await Promise.all(pkgNames.map(fetchPkg))
// Fetch download counts for each package // Fetch download counts for each package
spinner.text = chalk`Fetching package {cyan download counts} from {red npm}...`
const downloadCounts = await bulkFetchDownloads(pkgNames) const downloadCounts = await bulkFetchDownloads(pkgNames)
// Author name -> list of packages, ordered by download count
const authorInfos = computeAuthorInfos(allPkgs, downloadCounts) const authorInfos = computeAuthorInfos(allPkgs, downloadCounts)
const rows = Object.keys(authorInfos) const rows = Object.keys(authorInfos)
@ -59,12 +67,21 @@ async function init () {
chalk.underline('Dependencies') chalk.underline('Dependencies')
]) ])
if (rows.length) {
spinner.succeed(chalk`You depend on {cyan ${rows.length} authors} who are {magenta seeking donations!} ✨\n`)
printTable(rows)
} else {
spinner.succeed('You don\'t depend on any packages from maintainers seeking donations')
}
function printTable (rows) {
const tableOpts = { const tableOpts = {
stringLength: str => stripAnsi(str).length stringLength: str => stripAnsi(str).length
} }
const table = textTable(rows, tableOpts) const table = textTable(rows, tableOpts)
console.log(table) console.log(table + '\n')
}
async function fetchPkg (pkgName) { async function fetchPkg (pkgName) {
// The registry does not support fetching versions for scoped packages // The registry does not support fetching versions for scoped packages

1
package.json

@ -16,6 +16,7 @@
"got": "^8.0.3", "got": "^8.0.3",
"minimist": "^1.2.0", "minimist": "^1.2.0",
"npm-registry-client": "^8.5.0", "npm-registry-client": "^8.5.0",
"ora": "^1.4.0",
"pify": "^3.0.0", "pify": "^3.0.0",
"pkg-dir": "^2.0.0", "pkg-dir": "^2.0.0",
"read-package-tree": "^5.1.6", "read-package-tree": "^5.1.6",

Loading…
Cancel
Save