mirror of
https://github.com/vuejs/vue-cli.git
synced 2026-01-15 03:40:48 -06:00
112 lines
3.0 KiB
JavaScript
112 lines
3.0 KiB
JavaScript
const fs = require('fs')
|
|
const path = require('path')
|
|
const execa = require('execa')
|
|
const chalk = require('chalk')
|
|
const resolve = require('resolve')
|
|
const Generator = require('./Generator')
|
|
const { loadOptions } = require('./options')
|
|
const installDeps = require('./util/installDeps')
|
|
const {
|
|
log,
|
|
error,
|
|
hasYarn,
|
|
hasGit,
|
|
logWithSpinner,
|
|
stopSpinner
|
|
} = require('@vue/cli-shared-utils')
|
|
|
|
async function invoke (pluginName, options) {
|
|
delete options._
|
|
const context = process.cwd()
|
|
const pkgPath = path.resolve(context, 'package.json')
|
|
const isTestOrDebug = process.env.VUE_CLI_TEST || process.env.VUE_CLI_DEBUG
|
|
|
|
if (!fs.existsSync(pkgPath)) {
|
|
error(`package.json not found in ${chalk.yellow(context)}`)
|
|
process.exit(1)
|
|
}
|
|
|
|
const pkg = require(pkgPath)
|
|
|
|
// attempt to locate the plugin in package.json
|
|
const findPlugin = deps => {
|
|
if (!deps) return
|
|
let name
|
|
if (deps[name = `@vue/cli-plugin-${pluginName}`] ||
|
|
deps[name = `vue-cli-plugin-${pluginName}`] ||
|
|
deps[name = pluginName]) {
|
|
return name
|
|
}
|
|
}
|
|
|
|
const id = findPlugin(pkg.devDependencies) || findPlugin(pkg.dependencies)
|
|
if (!id) {
|
|
error(
|
|
`Cannot resolve plugin ${chalk.yellow(pluginName)} from package.json. ` +
|
|
`Did you forget to install it?`
|
|
)
|
|
process.exit(1)
|
|
}
|
|
|
|
const generatorURI = `${id}/generator`
|
|
const generatorPath = resolve.sync(generatorURI, { basedir: context })
|
|
const plugin = {
|
|
id,
|
|
apply: require(generatorPath),
|
|
options
|
|
}
|
|
|
|
const createCompleteCbs = []
|
|
const generator = new Generator(
|
|
context,
|
|
pkg,
|
|
[plugin],
|
|
isTestOrDebug ? false : loadOptions().useConfigFiles,
|
|
createCompleteCbs
|
|
)
|
|
|
|
log()
|
|
logWithSpinner('🚀', `Invoking generator for ${id}...`)
|
|
await generator.generate()
|
|
|
|
const newDeps = generator.pkg.dependencies
|
|
const newDevDeps = generator.pkg.devDependencies
|
|
const depsChanged = (
|
|
JSON.stringify(newDeps) !== JSON.stringify(pkg.dependencies) ||
|
|
JSON.stringify(newDevDeps) !== JSON.stringify(pkg.devDependencies)
|
|
)
|
|
|
|
if (!isTestOrDebug && depsChanged) {
|
|
logWithSpinner('📦', `Installing additional dependencies...`)
|
|
const packageManager = loadOptions().packageManager || (hasYarn ? 'yarn' : 'npm')
|
|
await installDeps(context, packageManager)
|
|
}
|
|
|
|
if (createCompleteCbs.length) {
|
|
logWithSpinner('⚓', `Running completion hooks...`)
|
|
for (const cb of createCompleteCbs) {
|
|
await cb()
|
|
}
|
|
}
|
|
|
|
stopSpinner()
|
|
|
|
log()
|
|
log(` Successfully invoked generator for plugin: ${chalk.cyan(id)}`)
|
|
if (hasGit) {
|
|
const { stdout } = await execa('git', ['ls-files', '--exclude-standard', '--modified', '--others'])
|
|
log(` The following files have been updated / added:\n`)
|
|
log(chalk.red(stdout.split(/\r?\n/g).map(line => ` ${line}`).join('\n')))
|
|
log()
|
|
}
|
|
log(` You should review and commit the changes.`)
|
|
log()
|
|
}
|
|
|
|
module.exports = (pluginName, options) => {
|
|
invoke(pluginName, options).catch(err => {
|
|
error(err)
|
|
process.exit(1)
|
|
})
|
|
}
|