39 lines
892 B
JavaScript
39 lines
892 B
JavaScript
|
const toUpperCase = (str) => str.charAt(0).toUpperCase() + str.slice(1)
|
|||
|
|
|||
|
module.exports = {
|
|||
|
description: 'Create vue component',
|
|||
|
prompts: [
|
|||
|
{
|
|||
|
type: 'input',
|
|||
|
name: 'name',
|
|||
|
message: '请输入组件名称(Please enter the component name)'
|
|||
|
}
|
|||
|
],
|
|||
|
actions: (data) => {
|
|||
|
const { name } = data
|
|||
|
const upperFirstName = toUpperCase(name)
|
|||
|
|
|||
|
const actions = []
|
|||
|
if (name) {
|
|||
|
actions.push({
|
|||
|
type: 'add',
|
|||
|
path: `./src/components/${upperFirstName}/src/${upperFirstName}.vue`,
|
|||
|
templateFile: './plop/component/component.hbs',
|
|||
|
data: {
|
|||
|
name,
|
|||
|
upperFirstName
|
|||
|
}
|
|||
|
}, {
|
|||
|
type: 'add',
|
|||
|
path: `./src/components/${upperFirstName}/index.ts`,
|
|||
|
templateFile: './plop/component/index.hbs',
|
|||
|
data: {
|
|||
|
upperFirstName
|
|||
|
}
|
|||
|
})
|
|||
|
}
|
|||
|
|
|||
|
return actions
|
|||
|
}
|
|||
|
}
|