generator-team
Version:
Generates an app with CI/CD in Team Foundation Server or Team Services
51 lines (44 loc) • 1.73 kB
JavaScript
const app = require(`./app.js`);
const util = require(`../app/utility`);
const argUtils = require(`../app/args`);
const prompts = require(`../app/prompt`);
const Generator = require(`yeoman-generator`);
module.exports = class extends Generator {
// The name `constructor` is important here
constructor(args, opts) {
// Calling the super constructor is important so our generator is correctly set up
super(args, opts);
// Order is important
argUtils.applicationName(this);
argUtils.tfs(this);
argUtils.pat(this);
}
// 2. Where you prompt users for options (where you`d call this.prompt())
prompting() {
// Collect any missing data from the user.
// This gives me access to the generator in the
// when callbacks of prompt
let cmdLnInput = this;
return this.prompt([
prompts.tfs(this),
prompts.pat(this),
prompts.applicationName(this)
]).then(function (answers) {
// Transfer answers to local object for use in the rest of the generator
this.pat = util.reconcileValue(cmdLnInput.options.pat, answers.pat);
this.tfs = util.reconcileValue(cmdLnInput.options.tfs, answers.tfs);
this.applicationName = util.reconcileValue(cmdLnInput.options.applicationName, answers.applicationName);
}.bind(this));
}
// 5. Where you write the generator specific files (routes, controllers, etc)
writing() {
var done = this.async();
var args = {
pat: this.pat,
tfs: this.tfs,
appName: this.applicationName,
project: this.applicationName
};
app.run(args, this, done);
}
};