import { inject } from 'aurelia-dependency-injection'; import { Project, ProjectItem, CLIOptions, UI } from 'aurelia-cli'; var path = require('path'); @inject(Project, CLIOptions, UI) export default class ElementGenerator { constructor(project, options, ui) { this.project = project; this.options = options; this.ui = ui; } async execute() { const name = await this.ui.ensureAnswer( this.options.args[0], 'What would you like to call the component?' ); const subFolders = await this.ui.ensureAnswer( this.options.args[1], "What sub-folder would you like to add it to?\nIf it doesn't exist it will be created for you.\n\nDefault folder is the source folder (src).", '.' ); let fileName = this.project.makeFileName(name); let className = this.project.makeClassName(name); this.project.root.add( ProjectItem.text( path.join(subFolders, fileName + '.js'), this.generateJSSource(className) ), ProjectItem.text( path.join(subFolders, fileName + '.html'), this.generateHTMLSource(className) ) ); await this.project.commitChanges(); await this.ui.log( `Created ${name} in the '${path.join( this.project.root.name, subFolders )}' folder` ); } generateJSSource(className) { return `export class ${className} { constructor() { this.message = 'Hello world'; } } `; } generateHTMLSource(className) { return ` `; } }