exports.id = 31; exports.ids = [31]; exports.modules = { /***/ 53692: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { "use strict"; const isObject = val => val !== null && typeof val === 'object' && !Array.isArray(val); const identity = val => val; /* eslint-disable no-control-regex */ // this is a modified version of https://github.com/chalk/ansi-regex (MIT License) const ANSI_REGEX = /[\u001b\u009b][[\]#;?()]*(?:(?:(?:[^\W_]*;?[^\W_]*)\u0007)|(?:(?:[0-9]{1,4}(;[0-9]{0,4})*)?[~0-9=<>cf-nqrtyA-PRZ]))/g; const create = () => { const colors = { enabled: true, visible: true, styles: {}, keys: {} }; if ('FORCE_COLOR' in process.env) { colors.enabled = process.env.FORCE_COLOR !== '0'; } const ansi = style => { let open = style.open = `\u001b[${style.codes[0]}m`; let close = style.close = `\u001b[${style.codes[1]}m`; let regex = style.regex = new RegExp(`\\u001b\\[${style.codes[1]}m`, 'g'); style.wrap = (input, newline) => { if (input.includes(close)) input = input.replace(regex, close + open); let output = open + input + close; // see https://github.com/chalk/chalk/pull/92, thanks to the // chalk contributors for this fix. However, we've confirmed that // this issue is also present in Windows terminals return newline ? output.replace(/\r*\n/g, `${close}$&${open}`) : output; }; return style; }; const wrap = (style, input, newline) => { return typeof style === 'function' ? style(input) : style.wrap(input, newline); }; const style = (input, stack) => { if (input === '' || input == null) return ''; if (colors.enabled === false) return input; if (colors.visible === false) return ''; let str = '' + input; let nl = str.includes('\n'); let n = stack.length; if (n > 0 && stack.includes('unstyle')) { stack = [...new Set(['unstyle', ...stack])].reverse(); } while (n-- > 0) str = wrap(colors.styles[stack[n]], str, nl); return str; }; const define = (name, codes, type) => { colors.styles[name] = ansi({ name, codes }); let keys = colors.keys[type] || (colors.keys[type] = []); keys.push(name); Reflect.defineProperty(colors, name, { configurable: true, enumerable: true, set(value) { colors.alias(name, value); }, get() { let color = input => style(input, color.stack); Reflect.setPrototypeOf(color, colors); color.stack = this.stack ? this.stack.concat(name) : [name]; return color; } }); }; define('reset', [0, 0], 'modifier'); define('bold', [1, 22], 'modifier'); define('dim', [2, 22], 'modifier'); define('italic', [3, 23], 'modifier'); define('underline', [4, 24], 'modifier'); define('inverse', [7, 27], 'modifier'); define('hidden', [8, 28], 'modifier'); define('strikethrough', [9, 29], 'modifier'); define('black', [30, 39], 'color'); define('red', [31, 39], 'color'); define('green', [32, 39], 'color'); define('yellow', [33, 39], 'color'); define('blue', [34, 39], 'color'); define('magenta', [35, 39], 'color'); define('cyan', [36, 39], 'color'); define('white', [37, 39], 'color'); define('gray', [90, 39], 'color'); define('grey', [90, 39], 'color'); define('bgBlack', [40, 49], 'bg'); define('bgRed', [41, 49], 'bg'); define('bgGreen', [42, 49], 'bg'); define('bgYellow', [43, 49], 'bg'); define('bgBlue', [44, 49], 'bg'); define('bgMagenta', [45, 49], 'bg'); define('bgCyan', [46, 49], 'bg'); define('bgWhite', [47, 49], 'bg'); define('blackBright', [90, 39], 'bright'); define('redBright', [91, 39], 'bright'); define('greenBright', [92, 39], 'bright'); define('yellowBright', [93, 39], 'bright'); define('blueBright', [94, 39], 'bright'); define('magentaBright', [95, 39], 'bright'); define('cyanBright', [96, 39], 'bright'); define('whiteBright', [97, 39], 'bright'); define('bgBlackBright', [100, 49], 'bgBright'); define('bgRedBright', [101, 49], 'bgBright'); define('bgGreenBright', [102, 49], 'bgBright'); define('bgYellowBright', [103, 49], 'bgBright'); define('bgBlueBright', [104, 49], 'bgBright'); define('bgMagentaBright', [105, 49], 'bgBright'); define('bgCyanBright', [106, 49], 'bgBright'); define('bgWhiteBright', [107, 49], 'bgBright'); colors.ansiRegex = ANSI_REGEX; colors.hasColor = colors.hasAnsi = str => { colors.ansiRegex.lastIndex = 0; return typeof str === 'string' && str !== '' && colors.ansiRegex.test(str); }; colors.alias = (name, color) => { let fn = typeof color === 'string' ? colors[color] : color; if (typeof fn !== 'function') { throw new TypeError('Expected alias to be the name of an existing color (string) or a function'); } if (!fn.stack) { Reflect.defineProperty(fn, 'name', { value: name }); colors.styles[name] = fn; fn.stack = [name]; } Reflect.defineProperty(colors, name, { configurable: true, enumerable: true, set(value) { colors.alias(name, value); }, get() { let color = input => style(input, color.stack); Reflect.setPrototypeOf(color, colors); color.stack = this.stack ? this.stack.concat(fn.stack) : fn.stack; return color; } }); }; colors.theme = custom => { if (!isObject(custom)) throw new TypeError('Expected theme to be an object'); for (let name of Object.keys(custom)) { colors.alias(name, custom[name]); } return colors; }; colors.alias('unstyle', str => { if (typeof str === 'string' && str !== '') { colors.ansiRegex.lastIndex = 0; return str.replace(colors.ansiRegex, ''); } return ''; }); colors.alias('noop', str => str); colors.none = colors.clear = colors.noop; colors.stripColor = colors.unstyle; colors.symbols = __webpack_require__(17142); colors.define = define; return colors; }; module.exports = create(); module.exports.create = create; /***/ }), /***/ 17142: /***/ ((module) => { "use strict"; const isHyper = process.env.TERM_PROGRAM === 'Hyper'; const isWindows = process.platform === 'win32'; const isLinux = process.platform === 'linux'; const common = { ballotDisabled: '☒', ballotOff: '☐', ballotOn: '☑', bullet: '•', bulletWhite: '◦', fullBlock: '█', heart: '❤', identicalTo: '≡', line: '─', mark: '※', middot: '·', minus: '-', multiplication: '×', obelus: '÷', pencilDownRight: '✎', pencilRight: '✏', pencilUpRight: '✐', percent: '%', pilcrow2: '❡', pilcrow: '¶', plusMinus: '±', section: '§', starsOff: '☆', starsOn: '★', upDownArrow: '↕' }; const windows = Object.assign({}, common, { check: '√', cross: '×', ellipsisLarge: '...', ellipsis: '...', info: 'i', question: '?', questionSmall: '?', pointer: '>', pointerSmall: '»', radioOff: '( )', radioOn: '(*)', warning: '‼' }); const other = Object.assign({}, common, { ballotCross: '✘', check: '✔', cross: '✖', ellipsisLarge: '⋯', ellipsis: '…', info: 'ℹ', question: '?', questionFull: '?', questionSmall: '﹖', pointer: isLinux ? '▸' : '❯', pointerSmall: isLinux ? '‣' : '›', radioOff: '◯', radioOn: '◉', warning: '⚠' }); module.exports = (isWindows && !isHyper) ? windows : other; Reflect.defineProperty(module.exports, 'common', { enumerable: false, value: common }); Reflect.defineProperty(module.exports, 'windows', { enumerable: false, value: windows }); Reflect.defineProperty(module.exports, 'other', { enumerable: false, value: other }); /***/ }), /***/ 84031: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { "use strict"; const assert = __webpack_require__(42357); const Events = __webpack_require__(28614); const utils = __webpack_require__(83546); /** * Create an instance of `Enquirer`. * * ```js * const Enquirer = require('enquirer'); * const enquirer = new Enquirer(); * ``` * @name Enquirer * @param {Object} `options` (optional) Options to use with all prompts. * @param {Object} `answers` (optional) Answers object to initialize with. * @api public */ class Enquirer extends Events { constructor(options, answers) { super(); this.options = utils.merge({}, options); this.answers = { ...answers }; } /** * Register a custom prompt type. * * ```js * const Enquirer = require('enquirer'); * const enquirer = new Enquirer(); * enquirer.register('customType', require('./custom-prompt')); * ``` * @name register() * @param {String} `type` * @param {Function|Prompt} `fn` `Prompt` class, or a function that returns a `Prompt` class. * @return {Object} Returns the Enquirer instance * @api public */ register(type, fn) { if (utils.isObject(type)) { for (let key of Object.keys(type)) this.register(key, type[key]); return this; } assert.equal(typeof fn, 'function', 'expected a function'); let name = type.toLowerCase(); if (fn.prototype instanceof this.Prompt) { this.prompts[name] = fn; } else { this.prompts[name] = fn(this.Prompt, this); } return this; } /** * Prompt function that takes a "question" object or array of question objects, * and returns an object with responses from the user. * * ```js * const Enquirer = require('enquirer'); * const enquirer = new Enquirer(); * * const response = await enquirer.prompt({ * type: 'input', * name: 'username', * message: 'What is your username?' * }); * console.log(response); * ``` * @name prompt() * @param {Array|Object} `questions` Options objects for one or more prompts to run. * @return {Promise} Promise that returns an "answers" object with the user's responses. * @api public */ async prompt(questions = []) { for (let question of [].concat(questions)) { try { if (typeof question === 'function') question = await question.call(this); await this.ask(utils.merge({}, this.options, question)); } catch (err) { return Promise.reject(err); } } return this.answers; } async ask(question) { if (typeof question === 'function') { question = await question.call(this); } let opts = utils.merge({}, this.options, question); let { type, name } = question; let { set, get } = utils; if (typeof type === 'function') { type = await type.call(this, question, this.answers); } if (!type) return this.answers[name]; assert(this.prompts[type], `Prompt "${type}" is not registered`); let prompt = new this.prompts[type](opts); let value = get(this.answers, name); prompt.state.answers = this.answers; prompt.enquirer = this; if (name) { prompt.on('submit', value => { this.emit('answer', name, value, prompt); set(this.answers, name, value); }); } // bubble events let emit = prompt.emit.bind(prompt); prompt.emit = (...args) => { this.emit.call(this, ...args); return emit(...args); }; this.emit('prompt', prompt, this); if (opts.autofill && value != null) { prompt.value = prompt.input = value; // if "autofill=show" render the prompt, otherwise stay "silent" if (opts.autofill === 'show') { await prompt.submit(); } } else { value = prompt.value = await prompt.run(); } return value; } /** * Use an enquirer plugin. * * ```js * const Enquirer = require('enquirer'); * const enquirer = new Enquirer(); * const plugin = enquirer => { * // do stuff to enquire instance * }; * enquirer.use(plugin); * ``` * @name use() * @param {Function} `plugin` Plugin function that takes an instance of Enquirer. * @return {Object} Returns the Enquirer instance. * @api public */ use(plugin) { plugin.call(this, this); return this; } set Prompt(value) { this._Prompt = value; } get Prompt() { return this._Prompt || this.constructor.Prompt; } get prompts() { return this.constructor.prompts; } static set Prompt(value) { this._Prompt = value; } static get Prompt() { return this._Prompt || __webpack_require__(232); } static get prompts() { return __webpack_require__(29594); } static get types() { return __webpack_require__(29920); } /** * Prompt function that takes a "question" object or array of question objects, * and returns an object with responses from the user. * * ```js * const { prompt } = require('enquirer'); * const response = await prompt({ * type: 'input', * name: 'username', * message: 'What is your username?' * }); * console.log(response); * ``` * @name Enquirer#prompt * @param {Array|Object} `questions` Options objects for one or more prompts to run. * @return {Promise} Promise that returns an "answers" object with the user's responses. * @api public */ static get prompt() { const fn = (questions, ...rest) => { let enquirer = new this(...rest); let emit = enquirer.emit.bind(enquirer); enquirer.emit = (...args) => { fn.emit(...args); return emit(...args); }; return enquirer.prompt(questions); }; utils.mixinEmitter(fn, new Events()); return fn; } } utils.mixinEmitter(Enquirer, new Events()); const prompts = Enquirer.prompts; for (let name of Object.keys(prompts)) { let key = name.toLowerCase(); let run = options => new prompts[name](options).run(); Enquirer.prompt[key] = run; Enquirer[key] = run; if (!Enquirer[name]) { Reflect.defineProperty(Enquirer, name, { get: () => prompts[name] }); } } const exp = name => { utils.defineExport(Enquirer, name, () => Enquirer.types[name]); }; exp('ArrayPrompt'); exp('AuthPrompt'); exp('BooleanPrompt'); exp('NumberPrompt'); exp('StringPrompt'); module.exports = Enquirer; /***/ }), /***/ 94907: /***/ ((module, exports, __webpack_require__) => { "use strict"; const isTerm = process.env.TERM_PROGRAM === 'Apple_Terminal'; const colors = __webpack_require__(53692); const utils = __webpack_require__(83546); const ansi = module.exports = exports; const ESC = '\u001b['; const BEL = '\u0007'; let hidden = false; const code = ansi.code = { bell: BEL, beep: BEL, beginning: `${ESC}G`, down: `${ESC}J`, esc: ESC, getPosition: `${ESC}6n`, hide: `${ESC}?25l`, line: `${ESC}2K`, lineEnd: `${ESC}K`, lineStart: `${ESC}1K`, restorePosition: ESC + (isTerm ? '8' : 'u'), savePosition: ESC + (isTerm ? '7' : 's'), screen: `${ESC}2J`, show: `${ESC}?25h`, up: `${ESC}1J` }; const cursor = ansi.cursor = { get hidden() { return hidden; }, hide() { hidden = true; return code.hide; }, show() { hidden = false; return code.show; }, forward: (count = 1) => `${ESC}${count}C`, backward: (count = 1) => `${ESC}${count}D`, nextLine: (count = 1) => `${ESC}E`.repeat(count), prevLine: (count = 1) => `${ESC}F`.repeat(count), up: (count = 1) => count ? `${ESC}${count}A` : '', down: (count = 1) => count ? `${ESC}${count}B` : '', right: (count = 1) => count ? `${ESC}${count}C` : '', left: (count = 1) => count ? `${ESC}${count}D` : '', to(x, y) { return y ? `${ESC}${y + 1};${x + 1}H` : `${ESC}${x + 1}G`; }, move(x = 0, y = 0) { let res = ''; res += (x < 0) ? cursor.left(-x) : (x > 0) ? cursor.right(x) : ''; res += (y < 0) ? cursor.up(-y) : (y > 0) ? cursor.down(y) : ''; return res; }, restore(state = {}) { let { after, cursor, initial, input, prompt, size, value } = state; initial = utils.isPrimitive(initial) ? String(initial) : ''; input = utils.isPrimitive(input) ? String(input) : ''; value = utils.isPrimitive(value) ? String(value) : ''; if (size) { let codes = ansi.cursor.up(size) + ansi.cursor.to(prompt.length); let diff = input.length - cursor; if (diff > 0) { codes += ansi.cursor.left(diff); } return codes; } if (value || after) { let pos = (!input && !!initial) ? -initial.length : -input.length + cursor; if (after) pos -= after.length; if (input === '' && initial && !prompt.includes(initial)) { pos += initial.length; } return ansi.cursor.move(pos); } } }; const erase = ansi.erase = { screen: code.screen, up: code.up, down: code.down, line: code.line, lineEnd: code.lineEnd, lineStart: code.lineStart, lines(n) { let str = ''; for (let i = 0; i < n; i++) { str += ansi.erase.line + (i < n - 1 ? ansi.cursor.up(1) : ''); } if (n) str += ansi.code.beginning; return str; } }; ansi.clear = (input = '', columns = process.stdout.columns) => { if (!columns) return erase.line + cursor.to(0); let width = str => [...colors.unstyle(str)].length; let lines = input.split(/\r?\n/); let rows = 0; for (let line of lines) { rows += 1 + Math.floor(Math.max(width(line) - 1, 0) / columns); } return (erase.line + cursor.prevLine()).repeat(rows - 1) + erase.line + cursor.to(0); }; /***/ }), /***/ 64726: /***/ ((__unused_webpack_module, exports) => { "use strict"; /** * Actions are mappings from keypress event names to method names * in the prompts. */ exports.ctrl = { a: 'first', b: 'backward', c: 'cancel', d: 'deleteForward', e: 'last', f: 'forward', g: 'reset', i: 'tab', k: 'cutForward', l: 'reset', n: 'newItem', m: 'cancel', j: 'submit', p: 'search', r: 'remove', s: 'save', u: 'undo', w: 'cutLeft', x: 'toggleCursor', v: 'paste' }; exports.shift = { up: 'shiftUp', down: 'shiftDown', left: 'shiftLeft', right: 'shiftRight', tab: 'prev' }; exports.fn = { up: 'pageUp', down: 'pageDown', left: 'pageLeft', right: 'pageRight', delete: 'deleteForward' }; // on Windows exports.option = { b: 'backward', f: 'forward', d: 'cutRight', left: 'cutLeft', up: 'altUp', down: 'altDown' }; exports.keys = { pageup: 'pageUp', // + (mac), (windows) pagedown: 'pageDown', // + (mac), (windows) home: 'home', // + (mac), (windows) end: 'end', // + (mac), (windows) cancel: 'cancel', delete: 'deleteForward', backspace: 'delete', down: 'down', enter: 'submit', escape: 'cancel', left: 'left', space: 'space', number: 'number', return: 'submit', right: 'right', tab: 'next', up: 'up' }; /***/ }), /***/ 73736: /***/ ((module) => { "use strict"; const unique = arr => arr.filter((v, i) => arr.lastIndexOf(v) === i); const compact = arr => unique(arr).filter(Boolean); module.exports = (action, data = {}, value = '') => { let { past = [], present = '' } = data; let rest, prev; switch (action) { case 'prev': case 'undo': rest = past.slice(0, past.length - 1); prev = past[past.length - 1] || ''; return { past: compact([value, ...rest]), present: prev }; case 'next': case 'redo': rest = past.slice(1); prev = past[0] || ''; return { past: compact([...rest, value]), present: prev }; case 'save': return { past: compact([...past, value]), present: '' }; case 'remove': prev = compact(past.filter(v => v !== value)); present = ''; if (prev.length) { present = prev.pop(); } return { past: prev, present }; default: { throw new Error(`Invalid action: "${action}"`); } } }; /***/ }), /***/ 27189: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { "use strict"; const colors = __webpack_require__(53692); const clean = (str = '') => { return typeof str === 'string' ? str.replace(/^['"]|['"]$/g, '') : ''; }; /** * This file contains the interpolation and rendering logic for * the Snippet prompt. */ class Item { constructor(token) { this.name = token.key; this.field = token.field || {}; this.value = clean(token.initial || this.field.initial || ''); this.message = token.message || this.name; this.cursor = 0; this.input = ''; this.lines = []; } } const tokenize = async(options = {}, defaults = {}, fn = token => token) => { let unique = new Set(); let fields = options.fields || []; let input = options.template; let tabstops = []; let items = []; let keys = []; let line = 1; if (typeof input === 'function') { input = await input(); } let i = -1; let next = () => input[++i]; let peek = () => input[i + 1]; let push = token => { token.line = line; tabstops.push(token); }; push({ type: 'bos', value: '' }); while (i < input.length - 1) { let value = next(); if (/^[^\S\n ]$/.test(value)) { push({ type: 'text', value }); continue; } if (value === '\n') { push({ type: 'newline', value }); line++; continue; } if (value === '\\') { value += next(); push({ type: 'text', value }); continue; } if ((value === '$' || value === '#' || value === '{') && peek() === '{') { let n = next(); value += n; let token = { type: 'template', open: value, inner: '', close: '', value }; let ch; while ((ch = next())) { if (ch === '}') { if (peek() === '}') ch += next(); token.value += ch; token.close = ch; break; } if (ch === ':') { token.initial = ''; token.key = token.inner; } else if (token.initial !== void 0) { token.initial += ch; } token.value += ch; token.inner += ch; } token.template = token.open + (token.initial || token.inner) + token.close; token.key = token.key || token.inner; if (defaults.hasOwnProperty(token.key)) { token.initial = defaults[token.key]; } token = fn(token); push(token); keys.push(token.key); unique.add(token.key); let item = items.find(item => item.name === token.key); token.field = fields.find(ch => ch.name === token.key); if (!item) { item = new Item(token); items.push(item); } item.lines.push(token.line - 1); continue; } let last = tabstops[tabstops.length - 1]; if (last.type === 'text' && last.line === line) { last.value += value; } else { push({ type: 'text', value }); } } push({ type: 'eos', value: '' }); return { input, tabstops, unique, keys, items }; }; module.exports = async prompt => { let options = prompt.options; let required = new Set(options.required === true ? [] : (options.required || [])); let defaults = { ...options.values, ...options.initial }; let { tabstops, items, keys } = await tokenize(options, defaults); let result = createFn('result', prompt, options); let format = createFn('format', prompt, options); let isValid = createFn('validate', prompt, options, true); let isVal = prompt.isValue.bind(prompt); return async(state = {}, submitted = false) => { let index = 0; state.required = required; state.items = items; state.keys = keys; state.output = ''; let validate = async(value, state, item, index) => { let error = await isValid(value, state, item, index); if (error === false) { return 'Invalid field ' + item.name; } return error; }; for (let token of tabstops) { let value = token.value; let key = token.key; if (token.type !== 'template') { if (value) state.output += value; continue; } if (token.type === 'template') { let item = items.find(ch => ch.name === key); if (options.required === true) { state.required.add(item.name); } let val = [item.input, state.values[item.value], item.value, value].find(isVal); let field = item.field || {}; let message = field.message || token.inner; if (submitted) { let error = await validate(state.values[key], state, item, index); if ((error && typeof error === 'string') || error === false) { state.invalid.set(key, error); continue; } state.invalid.delete(key); let res = await result(state.values[key], state, item, index); state.output += colors.unstyle(res); continue; } item.placeholder = false; let before = value; value = await format(value, state, item, index); if (val !== value) { state.values[key] = val; value = prompt.styles.typing(val); state.missing.delete(message); } else { state.values[key] = void 0; val = `<${message}>`; value = prompt.styles.primary(val); item.placeholder = true; if (state.required.has(key)) { state.missing.add(message); } } if (state.missing.has(message) && state.validating) { value = prompt.styles.warning(val); } if (state.invalid.has(key) && state.validating) { value = prompt.styles.danger(val); } if (index === state.index) { if (before !== value) { value = prompt.styles.underline(value); } else { value = prompt.styles.heading(colors.unstyle(value)); } } index++; } if (value) { state.output += value; } } let lines = state.output.split('\n').map(l => ' ' + l); let len = items.length; let done = 0; for (let item of items) { if (state.invalid.has(item.name)) { item.lines.forEach(i => { if (lines[i][0] !== ' ') return; lines[i] = state.styles.danger(state.symbols.bullet) + lines[i].slice(1); }); } if (prompt.isValue(state.values[item.name])) { done++; } } state.completed = ((done / len) * 100).toFixed(0); state.output = lines.join('\n'); return state.output; }; }; function createFn(prop, prompt, options, fallback) { return (value, state, item, index) => { if (typeof item.field[prop] === 'function') { return item.field[prop].call(prompt, value, state, item, index); } return [fallback, value].find(v => prompt.isValue(v)); }; } /***/ }), /***/ 28914: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { "use strict"; const readline = __webpack_require__(51058); const combos = __webpack_require__(64726); /* eslint-disable no-control-regex */ const metaKeyCodeRe = /^(?:\x1b)([a-zA-Z0-9])$/; const fnKeyRe = /^(?:\x1b+)(O|N|\[|\[\[)(?:(\d+)(?:;(\d+))?([~^$])|(?:1;)?(\d+)?([a-zA-Z]))/; const keyName = { /* xterm/gnome ESC O letter */ 'OP': 'f1', 'OQ': 'f2', 'OR': 'f3', 'OS': 'f4', /* xterm/rxvt ESC [ number ~ */ '[11~': 'f1', '[12~': 'f2', '[13~': 'f3', '[14~': 'f4', /* from Cygwin and used in libuv */ '[[A': 'f1', '[[B': 'f2', '[[C': 'f3', '[[D': 'f4', '[[E': 'f5', /* common */ '[15~': 'f5', '[17~': 'f6', '[18~': 'f7', '[19~': 'f8', '[20~': 'f9', '[21~': 'f10', '[23~': 'f11', '[24~': 'f12', /* xterm ESC [ letter */ '[A': 'up', '[B': 'down', '[C': 'right', '[D': 'left', '[E': 'clear', '[F': 'end', '[H': 'home', /* xterm/gnome ESC O letter */ 'OA': 'up', 'OB': 'down', 'OC': 'right', 'OD': 'left', 'OE': 'clear', 'OF': 'end', 'OH': 'home', /* xterm/rxvt ESC [ number ~ */ '[1~': 'home', '[2~': 'insert', '[3~': 'delete', '[4~': 'end', '[5~': 'pageup', '[6~': 'pagedown', /* putty */ '[[5~': 'pageup', '[[6~': 'pagedown', /* rxvt */ '[7~': 'home', '[8~': 'end', /* rxvt keys with modifiers */ '[a': 'up', '[b': 'down', '[c': 'right', '[d': 'left', '[e': 'clear', '[2$': 'insert', '[3$': 'delete', '[5$': 'pageup', '[6$': 'pagedown', '[7$': 'home', '[8$': 'end', 'Oa': 'up', 'Ob': 'down', 'Oc': 'right', 'Od': 'left', 'Oe': 'clear', '[2^': 'insert', '[3^': 'delete', '[5^': 'pageup', '[6^': 'pagedown', '[7^': 'home', '[8^': 'end', /* misc. */ '[Z': 'tab', } function isShiftKey(code) { return ['[a', '[b', '[c', '[d', '[e', '[2$', '[3$', '[5$', '[6$', '[7$', '[8$', '[Z'].includes(code) } function isCtrlKey(code) { return [ 'Oa', 'Ob', 'Oc', 'Od', 'Oe', '[2^', '[3^', '[5^', '[6^', '[7^', '[8^'].includes(code) } const keypress = (s = '', event = {}) => { let parts; let key = { name: event.name, ctrl: false, meta: false, shift: false, option: false, sequence: s, raw: s, ...event }; if (Buffer.isBuffer(s)) { if (s[0] > 127 && s[1] === void 0) { s[0] -= 128; s = '\x1b' + String(s); } else { s = String(s); } } else if (s !== void 0 && typeof s !== 'string') { s = String(s); } else if (!s) { s = key.sequence || ''; } key.sequence = key.sequence || s || key.name; if (s === '\r') { // carriage return key.raw = void 0; key.name = 'return'; } else if (s === '\n') { // enter, should have been called linefeed key.name = 'enter'; } else if (s === '\t') { // tab key.name = 'tab'; } else if (s === '\b' || s === '\x7f' || s === '\x1b\x7f' || s === '\x1b\b') { // backspace or ctrl+h key.name = 'backspace'; key.meta = s.charAt(0) === '\x1b'; } else if (s === '\x1b' || s === '\x1b\x1b') { // escape key key.name = 'escape'; key.meta = s.length === 2; } else if (s === ' ' || s === '\x1b ') { key.name = 'space'; key.meta = s.length === 2; } else if (s <= '\x1a') { // ctrl+letter key.name = String.fromCharCode(s.charCodeAt(0) + 'a'.charCodeAt(0) - 1); key.ctrl = true; } else if (s.length === 1 && s >= '0' && s <= '9') { // number key.name = 'number'; } else if (s.length === 1 && s >= 'a' && s <= 'z') { // lowercase letter key.name = s; } else if (s.length === 1 && s >= 'A' && s <= 'Z') { // shift+letter key.name = s.toLowerCase(); key.shift = true; } else if ((parts = metaKeyCodeRe.exec(s))) { // meta+character key key.meta = true; key.shift = /^[A-Z]$/.test(parts[1]); } else if ((parts = fnKeyRe.exec(s))) { let segs = [...s]; if (segs[0] === '\u001b' && segs[1] === '\u001b') { key.option = true; } // ansi escape sequence // reassemble the key code leaving out leading \x1b's, // the modifier key bitflag and any meaningless "1;" sequence let code = [parts[1], parts[2], parts[4], parts[6]].filter(Boolean).join(''); let modifier = (parts[3] || parts[5] || 1) - 1; // Parse the key modifier key.ctrl = !!(modifier & 4); key.meta = !!(modifier & 10); key.shift = !!(modifier & 1); key.code = code; key.name = keyName[code]; key.shift = isShiftKey(code) || key.shift; key.ctrl = isCtrlKey(code) || key.ctrl; } return key; }; keypress.listen = (options = {}, onKeypress) => { let { stdin } = options; if (!stdin || (stdin !== process.stdin && !stdin.isTTY)) { throw new Error('Invalid stream passed'); } let rl = readline.createInterface({ terminal: true, input: stdin }); readline.emitKeypressEvents(stdin, rl); let on = (buf, key) => onKeypress(buf, keypress(buf, key), rl); let isRaw = stdin.isRaw; if (stdin.isTTY) stdin.setRawMode(true); stdin.on('keypress', on); rl.resume(); let off = () => { if (stdin.isTTY) stdin.setRawMode(isRaw); stdin.removeListener('keypress', on); rl.pause(); rl.close(); }; return off; }; keypress.action = (buf, key, customActions) => { let obj = { ...combos, ...customActions }; if (key.ctrl) { key.action = obj.ctrl[key.name]; return key; } if (key.option && obj.option) { key.action = obj.option[key.name]; return key; } if (key.shift) { key.action = obj.shift[key.name]; return key; } key.action = obj.keys[key.name]; return key; }; module.exports = keypress; /***/ }), /***/ 12786: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { "use strict"; const utils = __webpack_require__(83546); /** * Render a placeholder value with cursor and styling based on the * position of the cursor. * * @param {Object} `prompt` Prompt instance. * @param {String} `input` Input string. * @param {String} `initial` The initial user-provided value. * @param {Number} `pos` Current cursor position. * @param {Boolean} `showCursor` Render a simulated cursor using the inverse primary style. * @return {String} Returns the styled placeholder string. * @api public */ module.exports = (prompt, options = {}) => { prompt.cursorHide(); let { input = '', initial = '', pos, showCursor = true, color } = options; let style = color || prompt.styles.placeholder; let inverse = utils.inverse(prompt.styles.primary); let blinker = str => inverse(prompt.styles.black(str)); let output = input; let char = ' '; let reverse = blinker(char); if (prompt.blink && prompt.blink.off === true) { blinker = str => str; reverse = ''; } if (showCursor && pos === 0 && initial === '' && input === '') { return blinker(char); } if (showCursor && pos === 0 && (input === initial || input === '')) { return blinker(initial[0]) + style(initial.slice(1)); } initial = utils.isPrimitive(initial) ? `${initial}` : ''; input = utils.isPrimitive(input) ? `${input}` : ''; let placeholder = initial && initial.startsWith(input) && initial !== input; let cursor = placeholder ? blinker(initial[input.length]) : reverse; if (pos !== input.length && showCursor === true) { output = input.slice(0, pos) + blinker(input[pos]) + input.slice(pos + 1); cursor = ''; } if (showCursor === false) { cursor = ''; } if (placeholder) { let raw = prompt.styles.unstyle(output + cursor); return output + cursor + style(initial.slice(raw.length)); } return output + cursor; }; /***/ }), /***/ 232: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { "use strict"; const Events = __webpack_require__(28614); const colors = __webpack_require__(53692); const keypress = __webpack_require__(28914); const timer = __webpack_require__(33940); const State = __webpack_require__(36873); const theme = __webpack_require__(39227); const utils = __webpack_require__(83546); const ansi = __webpack_require__(94907); /** * Base class for creating a new Prompt. * @param {Object} `options` Question object. */ class Prompt extends Events { constructor(options = {}) { super(); this.name = options.name; this.type = options.type; this.options = options; theme(this); timer(this); this.state = new State(this); this.initial = [options.initial, options.default].find(v => v != null); this.stdout = options.stdout || process.stdout; this.stdin = options.stdin || process.stdin; this.scale = options.scale || 1; this.term = this.options.term || process.env.TERM_PROGRAM; this.margin = margin(this.options.margin); this.setMaxListeners(0); setOptions(this); } async keypress(input, event = {}) { this.keypressed = true; let key = keypress.action(input, keypress(input, event), this.options.actions); this.state.keypress = key; this.emit('keypress', input, key); this.emit('state', this.state.clone()); let fn = this.options[key.action] || this[key.action] || this.dispatch; if (typeof fn === 'function') { return await fn.call(this, input, key); } this.alert(); } alert() { delete this.state.alert; if (this.options.show === false) { this.emit('alert'); } else { this.stdout.write(ansi.code.beep); } } cursorHide() { this.stdout.write(ansi.cursor.hide()); utils.onExit(() => this.cursorShow()); } cursorShow() { this.stdout.write(ansi.cursor.show()); } write(str) { if (!str) return; if (this.stdout && this.state.show !== false) { this.stdout.write(str); } this.state.buffer += str; } clear(lines = 0) { let buffer = this.state.buffer; this.state.buffer = ''; if ((!buffer && !lines) || this.options.show === false) return; this.stdout.write(ansi.cursor.down(lines) + ansi.clear(buffer, this.width)); } restore() { if (this.state.closed || this.options.show === false) return; let { prompt, after, rest } = this.sections(); let { cursor, initial = '', input = '', value = '' } = this; let size = this.state.size = rest.length; let state = { after, cursor, initial, input, prompt, size, value }; let codes = ansi.cursor.restore(state); if (codes) { this.stdout.write(codes); } } sections() { let { buffer, input, prompt } = this.state; prompt = colors.unstyle(prompt); let buf = colors.unstyle(buffer); let idx = buf.indexOf(prompt); let header = buf.slice(0, idx); let rest = buf.slice(idx); let lines = rest.split('\n'); let first = lines[0]; let last = lines[lines.length - 1]; let promptLine = prompt + (input ? ' ' + input : ''); let len = promptLine.length; let after = len < first.length ? first.slice(len + 1) : ''; return { header, prompt: first, after, rest: lines.slice(1), last }; } async submit() { this.state.submitted = true; this.state.validating = true; // this will only be called when the prompt is directly submitted // without initializing, i.e. when the prompt is skipped, etc. Otherwize, // "options.onSubmit" is will be handled by the "initialize()" method. if (this.options.onSubmit) { await this.options.onSubmit.call(this, this.name, this.value, this); } let result = this.state.error || await this.validate(this.value, this.state); if (result !== true) { let error = '\n' + this.symbols.pointer + ' '; if (typeof result === 'string') { error += result.trim(); } else { error += 'Invalid input'; } this.state.error = '\n' + this.styles.danger(error); this.state.submitted = false; await this.render(); await this.alert(); this.state.validating = false; this.state.error = void 0; return; } this.state.validating = false; await this.render(); await this.close(); this.value = await this.result(this.value); this.emit('submit', this.value); } async cancel(err) { this.state.cancelled = this.state.submitted = true; await this.render(); await this.close(); if (typeof this.options.onCancel === 'function') { await this.options.onCancel.call(this, this.name, this.value, this); } this.emit('cancel', await this.error(err)); } async close() { this.state.closed = true; try { let sections = this.sections(); let lines = Math.ceil(sections.prompt.length / this.width); if (sections.rest) { this.write(ansi.cursor.down(sections.rest.length)); } this.write('\n'.repeat(lines)); } catch (err) { /* do nothing */ } this.emit('close'); } start() { if (!this.stop && this.options.show !== false) { this.stop = keypress.listen(this, this.keypress.bind(this)); this.once('close', this.stop); } } async skip() { this.skipped = this.options.skip === true; if (typeof this.options.skip === 'function') { this.skipped = await this.options.skip.call(this, this.name, this.value); } return this.skipped; } async initialize() { let { format, options, result } = this; this.format = () => format.call(this, this.value); this.result = () => result.call(this, this.value); if (typeof options.initial === 'function') { this.initial = await options.initial.call(this, this); } if (typeof options.onRun === 'function') { await options.onRun.call(this, this); } // if "options.onSubmit" is defined, we wrap the "submit" method to guarantee // that "onSubmit" will always called first thing inside the submit // method, regardless of how it's handled in inheriting prompts. if (typeof options.onSubmit === 'function') { let onSubmit = options.onSubmit.bind(this); let submit = this.submit.bind(this); delete this.options.onSubmit; this.submit = async() => { await onSubmit(this.name, this.value, this); return submit(); }; } await this.start(); await this.render(); } render() { throw new Error('expected prompt to have a custom render method'); } run() { return new Promise(async(resolve, reject) => { this.once('submit', resolve); this.once('cancel', reject); if (await this.skip()) { this.render = () => {}; return this.submit(); } await this.initialize(); this.emit('run'); }); } async element(name, choice, i) { let { options, state, symbols, timers } = this; let timer = timers && timers[name]; state.timer = timer; let value = options[name] || state[name] || symbols[name]; let val = choice && choice[name] != null ? choice[name] : await value; if (val === '') return val; let res = await this.resolve(val, state, choice, i); if (!res && choice && choice[name]) { return this.resolve(value, state, choice, i); } return res; } async prefix() { let element = await this.element('prefix') || this.symbols; let timer = this.timers && this.timers.prefix; let state = this.state; state.timer = timer; if (utils.isObject(element)) element = element[state.status] || element.pending; if (!utils.hasColor(element)) { let style = this.styles[state.status] || this.styles.pending; return style(element); } return element; } async message() { let message = await this.element('message'); if (!utils.hasColor(message)) { return this.styles.strong(message); } return message; } async separator() { let element = await this.element('separator') || this.symbols; let timer = this.timers && this.timers.separator; let state = this.state; state.timer = timer; let value = element[state.status] || element.pending || state.separator; let ele = await this.resolve(value, state); if (utils.isObject(ele)) ele = ele[state.status] || ele.pending; if (!utils.hasColor(ele)) { return this.styles.muted(ele); } return ele; } async pointer(choice, i) { let val = await this.element('pointer', choice, i); if (typeof val === 'string' && utils.hasColor(val)) { return val; } if (val) { let styles = this.styles; let focused = this.index === i; let style = focused ? styles.primary : val => val; let ele = await this.resolve(val[focused ? 'on' : 'off'] || val, this.state); let styled = !utils.hasColor(ele) ? style(ele) : ele; return focused ? styled : ' '.repeat(ele.length); } } async indicator(choice, i) { let val = await this.element('indicator', choice, i); if (typeof val === 'string' && utils.hasColor(val)) { return val; } if (val) { let styles = this.styles; let enabled = choice.enabled === true; let style = enabled ? styles.success : styles.dark; let ele = val[enabled ? 'on' : 'off'] || val; return !utils.hasColor(ele) ? style(ele) : ele; } return ''; } body() { return null; } footer() { if (this.state.status === 'pending') { return this.element('footer'); } } header() { if (this.state.status === 'pending') { return this.element('header'); } } async hint() { if (this.state.status === 'pending' && !this.isValue(this.state.input)) { let hint = await this.element('hint'); if (!utils.hasColor(hint)) { return this.styles.muted(hint); } return hint; } } error(err) { return !this.state.submitted ? (err || this.state.error) : ''; } format(value) { return value; } result(value) { return value; } validate(value) { if (this.options.required === true) { return this.isValue(value); } return true; } isValue(value) { return value != null && value !== ''; } resolve(value, ...args) { return utils.resolve(this, value, ...args); } get base() { return Prompt.prototype; } get style() { return this.styles[this.state.status]; } get height() { return this.options.rows || utils.height(this.stdout, 25); } get width() { return this.options.columns || utils.width(this.stdout, 80); } get size() { return { width: this.width, height: this.height }; } set cursor(value) { this.state.cursor = value; } get cursor() { return this.state.cursor; } set input(value) { this.state.input = value; } get input() { return this.state.input; } set value(value) { this.state.value = value; } get value() { let { input, value } = this.state; let result = [value, input].find(this.isValue.bind(this)); return this.isValue(result) ? result : this.initial; } static get prompt() { return options => new this(options).run(); } } function setOptions(prompt) { let isValidKey = key => { return prompt[key] === void 0 || typeof prompt[key] === 'function'; }; let ignore = [ 'actions', 'choices', 'initial', 'margin', 'roles', 'styles', 'symbols', 'theme', 'timers', 'value' ]; let ignoreFn = [ 'body', 'footer', 'error', 'header', 'hint', 'indicator', 'message', 'prefix', 'separator', 'skip' ]; for (let key of Object.keys(prompt.options)) { if (ignore.includes(key)) continue; if (/^on[A-Z]/.test(key)) continue; let option = prompt.options[key]; if (typeof option === 'function' && isValidKey(key)) { if (!ignoreFn.includes(key)) { prompt[key] = option.bind(prompt); } } else if (typeof prompt[key] !== 'function') { prompt[key] = option; } } } function margin(value) { if (typeof value === 'number') { value = [value, value, value, value]; } let arr = [].concat(value || []); let pad = i => i % 2 === 0 ? '\n' : ' '; let res = []; for (let i = 0; i < 4; i++) { let char = pad(i); if (arr[i]) { res.push(char.repeat(arr[i])); } else { res.push(''); } } return res; } module.exports = Prompt; /***/ }), /***/ 89317: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { "use strict"; const Select = __webpack_require__(13466); const highlight = (input, color) => { let val = input.toLowerCase(); return str => { let s = str.toLowerCase(); let i = s.indexOf(val); let colored = color(str.slice(i, i + val.length)); return i >= 0 ? str.slice(0, i) + colored + str.slice(i + val.length) : str; }; }; class AutoComplete extends Select { constructor(options) { super(options); this.cursorShow(); } moveCursor(n) { this.state.cursor += n; } dispatch(ch) { return this.append(ch); } space(ch) { return this.options.multiple ? super.space(ch) : this.append(ch); } append(ch) { let { cursor, input } = this.state; this.input = input.slice(0, cursor) + ch + input.slice(cursor); this.moveCursor(1); return this.complete(); } delete() { let { cursor, input } = this.state; if (!input) return this.alert(); this.input = input.slice(0, cursor - 1) + input.slice(cursor); this.moveCursor(-1); return this.complete(); } deleteForward() { let { cursor, input } = this.state; if (input[cursor] === void 0) return this.alert(); this.input = `${input}`.slice(0, cursor) + `${input}`.slice(cursor + 1); return this.complete(); } number(ch) { return this.append(ch); } async complete() { this.completing = true; this.choices = await this.suggest(this.input, this.state._choices); this.state.limit = void 0; // allow getter/setter to reset limit this.index = Math.min(Math.max(this.visible.length - 1, 0), this.index); await this.render(); this.completing = false; } suggest(input = this.input, choices = this.state._choices) { if (typeof this.options.suggest === 'function') { return this.options.suggest.call(this, input, choices); } let str = input.toLowerCase(); return choices.filter(ch => ch.message.toLowerCase().includes(str)); } pointer() { return ''; } format() { if (!this.focused) return this.input; if (this.options.multiple && this.state.submitted) { return this.selected.map(ch => this.styles.primary(ch.message)).join(', '); } if (this.state.submitted) { let value = this.value = this.input = this.focused.value; return this.styles.primary(value); } return this.input; } async render() { if (this.state.status !== 'pending') return super.render(); let style = this.options.highlight ? this.options.highlight.bind(this) : this.styles.placeholder; let color = highlight(this.input, style); let choices = this.choices; this.choices = choices.map(ch => ({ ...ch, message: color(ch.message) })); await super.render(); this.choices = choices; } submit() { if (this.options.multiple) { this.value = this.selected.map(ch => ch.name); } return super.submit(); } } module.exports = AutoComplete; /***/ }), /***/ 7186: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { "use strict"; const AuthPrompt = __webpack_require__(66926); function defaultAuthenticate(value, state) { if (value.username === this.options.username && value.password === this.options.password) { return true; } return false; } const factory = (authenticate = defaultAuthenticate) => { const choices = [ { name: 'username', message: 'username' }, { name: 'password', message: 'password', format(input) { if (this.options.showPassword) { return input; } let color = this.state.submitted ? this.styles.primary : this.styles.muted; return color(this.symbols.asterisk.repeat(input.length)); } } ]; class BasicAuthPrompt extends AuthPrompt.create(authenticate) { constructor(options) { super({ ...options, choices }); } static create(authenticate) { return factory(authenticate); } } return BasicAuthPrompt; }; module.exports = factory(); /***/ }), /***/ 31291: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { "use strict"; const BooleanPrompt = __webpack_require__(23838); class ConfirmPrompt extends BooleanPrompt { constructor(options) { super(options); this.default = this.options.default || (this.initial ? '(Y/n)' : '(y/N)'); } } module.exports = ConfirmPrompt; /***/ }), /***/ 50848: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { "use strict"; const Select = __webpack_require__(13466); const Form = __webpack_require__(21826); const form = Form.prototype; class Editable extends Select { constructor(options) { super({ ...options, multiple: true }); this.align = [this.options.align, 'left'].find(v => v != null); this.emptyError = ''; this.values = {}; } dispatch(char, key) { let choice = this.focused; let parent = choice.parent || {}; if (!choice.editable && !parent.editable) { if (char === 'a' || char === 'i') return super[char](); } return form.dispatch.call(this, char, key); } append(char, key) { return form.append.call(this, char, key); } delete(char, key) { return form.delete.call(this, char, key); } space(char) { return this.focused.editable ? this.append(char) : super.space(); } number(char) { return this.focused.editable ? this.append(char) : super.number(char); } next() { return this.focused.editable ? form.next.call(this) : super.next(); } prev() { return this.focused.editable ? form.prev.call(this) : super.prev(); } async indicator(choice, i) { let symbol = choice.indicator || ''; let value = choice.editable ? symbol : super.indicator(choice, i); return await this.resolve(value, this.state, choice, i) || ''; } indent(choice) { return choice.role === 'heading' ? '' : (choice.editable ? ' ' : ' '); } async renderChoice(choice, i) { choice.indent = ''; if (choice.editable) return form.renderChoice.call(this, choice, i); return super.renderChoice(choice, i); } error() { return ''; } footer() { return this.state.error; } async validate() { let result = true; for (let choice of this.choices) { if (typeof choice.validate !== 'function') { continue; } if (choice.role === 'heading') { continue; } let val = choice.parent ? this.value[choice.parent.name] : this.value; if (choice.editable) { val = choice.value === choice.name ? choice.initial || '' : choice.value; } else if (!this.isDisabled(choice)) { val = choice.enabled === true; } result = await choice.validate(val, this.state); if (result !== true) { break; } } if (result !== true) { this.state.error = typeof result === 'string' ? result : 'Invalid Input'; } return result; } submit() { if (this.focused.newChoice === true) return super.submit(); if (this.choices.some(ch => ch.newChoice)) { return this.alert(); } this.value = {}; for (let choice of this.choices) { let val = choice.parent ? this.value[choice.parent.name] : this.value; if (choice.role === 'heading') { this.value[choice.name] = {}; continue; } if (choice.editable) { val[choice.name] = choice.value === choice.name ? (choice.initial || '') : choice.value; } else if (!this.isDisabled(choice)) { val[choice.name] = choice.enabled === true; } } return this.base.submit.call(this); } } module.exports = Editable; /***/ }), /***/ 21826: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { "use strict"; const colors = __webpack_require__(53692); const SelectPrompt = __webpack_require__(13466); const placeholder = __webpack_require__(12786); class FormPrompt extends SelectPrompt { constructor(options) { super({ ...options, multiple: true }); this.type = 'form'; this.initial = this.options.initial; this.align = [this.options.align, 'right'].find(v => v != null); this.emptyError = ''; this.values = {}; } async reset(first) { await super.reset(); if (first === true) this._index = this.index; this.index = this._index; this.values = {}; this.choices.forEach(choice => choice.reset && choice.reset()); return this.render(); } dispatch(char) { return !!char && this.append(char); } append(char) { let choice = this.focused; if (!choice) return this.alert(); let { cursor, input } = choice; choice.value = choice.input = input.slice(0, cursor) + char + input.slice(cursor); choice.cursor++; return this.render(); } delete() { let choice = this.focused; if (!choice || choice.cursor <= 0) return this.alert(); let { cursor, input } = choice; choice.value = choice.input = input.slice(0, cursor - 1) + input.slice(cursor); choice.cursor--; return this.render(); } deleteForward() { let choice = this.focused; if (!choice) return this.alert(); let { cursor, input } = choice; if (input[cursor] === void 0) return this.alert(); let str = `${input}`.slice(0, cursor) + `${input}`.slice(cursor + 1); choice.value = choice.input = str; return this.render(); } right() { let choice = this.focused; if (!choice) return this.alert(); if (choice.cursor >= choice.input.length) return this.alert(); choice.cursor++; return this.render(); } left() { let choice = this.focused; if (!choice) return this.alert(); if (choice.cursor <= 0) return this.alert(); choice.cursor--; return this.render(); } space(ch, key) { return this.dispatch(ch, key); } number(ch, key) { return this.dispatch(ch, key); } next() { let ch = this.focused; if (!ch) return this.alert(); let { initial, input } = ch; if (initial && initial.startsWith(input) && input !== initial) { ch.value = ch.input = initial; ch.cursor = ch.value.length; return this.render(); } return super.next(); } prev() { let ch = this.focused; if (!ch) return this.alert(); if (ch.cursor === 0) return super.prev(); ch.value = ch.input = ''; ch.cursor = 0; return this.render(); } separator() { return ''; } format(value) { return !this.state.submitted ? super.format(value) : ''; } pointer() { return ''; } indicator(choice) { return choice.input ? '⦿' : '⊙'; } async choiceSeparator(choice, i) { let sep = await this.resolve(choice.separator, this.state, choice, i) || ':'; return sep ? ' ' + this.styles.disabled(sep) : ''; } async renderChoice(choice, i) { await this.onChoice(choice, i); let { state, styles } = this; let { cursor, initial = '', name, hint, input = '' } = choice; let { muted, submitted, primary, danger } = styles; let help = hint; let focused = this.index === i; let validate = choice.validate || (() => true); let sep = await this.choiceSeparator(choice, i); let msg = choice.message; if (this.align === 'right') msg = msg.padStart(this.longest + 1, ' '); if (this.align === 'left') msg = msg.padEnd(this.longest + 1, ' '); // re-populate the form values (answers) object let value = this.values[name] = (input || initial); let color = input ? 'success' : 'dark'; if ((await validate.call(choice, value, this.state)) !== true) { color = 'danger'; } let style = styles[color]; let indicator = style(await this.indicator(choice, i)) + (choice.pad || ''); let indent = this.indent(choice); let line = () => [indent, indicator, msg + sep, input, help].filter(Boolean).join(' '); if (state.submitted) { msg = colors.unstyle(msg); input = submitted(input); help = ''; return line(); } if (choice.format) { input = await choice.format.call(this, input, choice, i); } else { let color = this.styles.muted; let options = { input, initial, pos: cursor, showCursor: focused, color }; input = placeholder(this, options); } if (!this.isValue(input)) { input = this.styles.muted(this.symbols.ellipsis); } if (choice.result) { this.values[name] = await choice.result.call(this, value, choice, i); } if (focused) { msg = primary(msg); } if (choice.error) { input += (input ? ' ' : '') + danger(choice.error.trim()); } else if (choice.hint) { input += (input ? ' ' : '') + muted(choice.hint.trim()); } return line(); } async submit() { this.value = this.values; return super.base.submit.call(this); } } module.exports = FormPrompt; /***/ }), /***/ 29594: /***/ ((__unused_webpack_module, exports, __webpack_require__) => { "use strict"; const utils = __webpack_require__(83546); const define = (key, fn) => { utils.defineExport(exports, key, fn); utils.defineExport(exports, key.toLowerCase(), fn); }; define('AutoComplete', () => __webpack_require__(89317)); define('BasicAuth', () => __webpack_require__(7186)); define('Confirm', () => __webpack_require__(31291)); define('Editable', () => __webpack_require__(50848)); define('Form', () => __webpack_require__(21826)); define('Input', () => __webpack_require__(66719)); define('Invisible', () => __webpack_require__(99822)); define('List', () => __webpack_require__(16795)); define('MultiSelect', () => __webpack_require__(91056)); define('Numeral', () => __webpack_require__(17403)); define('Password', () => __webpack_require__(46847)); define('Scale', () => __webpack_require__(17813)); define('Select', () => __webpack_require__(13466)); define('Snippet', () => __webpack_require__(19451)); define('Sort', () => __webpack_require__(7144)); define('Survey', () => __webpack_require__(83755)); define('Text', () => __webpack_require__(5781)); define('Toggle', () => __webpack_require__(10653)); define('Quiz', () => __webpack_require__(92249)); /***/ }), /***/ 66719: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { "use strict"; const Prompt = __webpack_require__(43391); const completer = __webpack_require__(73736); class Input extends Prompt { constructor(options) { super(options); let history = this.options.history; if (history && history.store) { let initial = history.values || this.initial; this.autosave = !!history.autosave; this.store = history.store; this.data = this.store.get('values') || { past: [], present: initial }; this.initial = this.data.present || this.data.past[this.data.past.length - 1]; } } completion(action) { if (!this.store) return this.alert(); this.data = completer(action, this.data, this.input); if (!this.data.present) return this.alert(); this.input = this.data.present; this.cursor = this.input.length; return this.render(); } altUp() { return this.completion('prev'); } altDown() { return this.completion('next'); } prev() { this.save(); return super.prev(); } save() { if (!this.store) return; this.data = completer('save', this.data, this.input); this.store.set('values', this.data); } submit() { if (this.store && this.autosave === true) { this.save(); } return super.submit(); } } module.exports = Input; /***/ }), /***/ 99822: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { "use strict"; const StringPrompt = __webpack_require__(43391); class InvisiblePrompt extends StringPrompt { format() { return ''; } } module.exports = InvisiblePrompt; /***/ }), /***/ 16795: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { "use strict"; const StringPrompt = __webpack_require__(43391); class ListPrompt extends StringPrompt { constructor(options = {}) { super(options); this.sep = this.options.separator || /, */; this.initial = options.initial || ''; } split(input = this.value) { return input ? String(input).split(this.sep) : []; } format() { let style = this.state.submitted ? this.styles.primary : val => val; return this.list.map(style).join(', '); } async submit(value) { let result = this.state.error || await this.validate(this.list, this.state); if (result !== true) { this.state.error = result; return super.submit(); } this.value = this.list; return super.submit(); } get list() { return this.split(); } } module.exports = ListPrompt; /***/ }), /***/ 91056: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { "use strict"; const Select = __webpack_require__(13466); class MultiSelect extends Select { constructor(options) { super({ ...options, multiple: true }); } } module.exports = MultiSelect; /***/ }), /***/ 17403: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { module.exports = __webpack_require__(45376); /***/ }), /***/ 46847: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { "use strict"; const StringPrompt = __webpack_require__(43391); class PasswordPrompt extends StringPrompt { constructor(options) { super(options); this.cursorShow(); } format(input = this.input) { if (!this.keypressed) return ''; let color = this.state.submitted ? this.styles.primary : this.styles.muted; return color(this.symbols.asterisk.repeat(input.length)); } } module.exports = PasswordPrompt; /***/ }), /***/ 92249: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { "use strict"; const SelectPrompt = __webpack_require__(13466); class Quiz extends SelectPrompt { constructor(options) { super(options); if (typeof this.options.correctChoice !== 'number' || this.options.correctChoice < 0) { throw new Error('Please specify the index of the correct answer from the list of choices'); } } async toChoices(value, parent) { let choices = await super.toChoices(value, parent); if (choices.length < 2) { throw new Error('Please give at least two choices to the user'); } if (this.options.correctChoice > choices.length) { throw new Error('Please specify the index of the correct answer from the list of choices'); } return choices; } check(state) { return state.index === this.options.correctChoice; } async result(selected) { return { selectedAnswer: selected, correctAnswer: this.options.choices[this.options.correctChoice].value, correct: await this.check(this.state) }; } } module.exports = Quiz; /***/ }), /***/ 17813: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { "use strict"; const colors = __webpack_require__(53692); const ArrayPrompt = __webpack_require__(98575); const utils = __webpack_require__(83546); class LikertScale extends ArrayPrompt { constructor(options = {}) { super(options); this.widths = [].concat(options.messageWidth || 50); this.align = [].concat(options.align || 'left'); this.linebreak = options.linebreak || false; this.edgeLength = options.edgeLength || 3; this.newline = options.newline || '\n '; let start = options.startNumber || 1; if (typeof this.scale === 'number') { this.scaleKey = false; this.scale = Array(this.scale).fill(0).map((v, i) => ({ name: i + start })); } } async reset() { this.tableized = false; await super.reset(); return this.render(); } tableize() { if (this.tableized === true) return; this.tableized = true; let longest = 0; for (let ch of this.choices) { longest = Math.max(longest, ch.message.length); ch.scaleIndex = ch.initial || 2; ch.scale = []; for (let i = 0; i < this.scale.length; i++) { ch.scale.push({ index: i }); } } this.widths[0] = Math.min(this.widths[0], longest + 3); } async dispatch(s, key) { if (this.multiple) { return this[key.name] ? await this[key.name](s, key) : await super.dispatch(s, key); } this.alert(); } heading(msg, item, i) { return this.styles.strong(msg); } separator() { return this.styles.muted(this.symbols.ellipsis); } right() { let choice = this.focused; if (choice.scaleIndex >= this.scale.length - 1) return this.alert(); choice.scaleIndex++; return this.render(); } left() { let choice = this.focused; if (choice.scaleIndex <= 0) return this.alert(); choice.scaleIndex--; return this.render(); } indent() { return ''; } format() { if (this.state.submitted) { let values = this.choices.map(ch => this.styles.info(ch.index)); return values.join(', '); } return ''; } pointer() { return ''; } /** * Render the scale "Key". Something like: * @return {String} */ renderScaleKey() { if (this.scaleKey === false) return ''; if (this.state.submitted) return ''; let scale = this.scale.map(item => ` ${item.name} - ${item.message}`); let key = ['', ...scale].map(item => this.styles.muted(item)); return key.join('\n'); } /** * Render the heading row for the scale. * @return {String} */ renderScaleHeading(max) { let keys = this.scale.map(ele => ele.name); if (typeof this.options.renderScaleHeading === 'function') { keys = this.options.renderScaleHeading.call(this, max); } let diff = this.scaleLength - keys.join('').length; let spacing = Math.round(diff / (keys.length - 1)); let names = keys.map(key => this.styles.strong(key)); let headings = names.join(' '.repeat(spacing)); let padding = ' '.repeat(this.widths[0]); return this.margin[3] + padding + this.margin[1] + headings; } /** * Render a scale indicator => ◯ or ◉ by default */ scaleIndicator(choice, item, i) { if (typeof this.options.scaleIndicator === 'function') { return this.options.scaleIndicator.call(this, choice, item, i); } let enabled = choice.scaleIndex === item.index; if (item.disabled) return this.styles.hint(this.symbols.radio.disabled); if (enabled) return this.styles.success(this.symbols.radio.on); return this.symbols.radio.off; } /** * Render the actual scale => ◯────◯────◉────◯────◯ */ renderScale(choice, i) { let scale = choice.scale.map(item => this.scaleIndicator(choice, item, i)); let padding = this.term === 'Hyper' ? '' : ' '; return scale.join(padding + this.symbols.line.repeat(this.edgeLength)); } /** * Render a choice, including scale => * "The website is easy to navigate. ◯───◯───◉───◯───◯" */ async renderChoice(choice, i) { await this.onChoice(choice, i); let focused = this.index === i; let pointer = await this.pointer(choice, i); let hint = await choice.hint; if (hint && !utils.hasColor(hint)) { hint = this.styles.muted(hint); } let pad = str => this.margin[3] + str.replace(/\s+$/, '').padEnd(this.widths[0], ' '); let newline = this.newline; let ind = this.indent(choice); let message = await this.resolve(choice.message, this.state, choice, i); let scale = await this.renderScale(choice, i); let margin = this.margin[1] + this.margin[3]; this.scaleLength = colors.unstyle(scale).length; this.widths[0] = Math.min(this.widths[0], this.width - this.scaleLength - margin.length); let msg = utils.wordWrap(message, { width: this.widths[0], newline }); let lines = msg.split('\n').map(line => pad(line) + this.margin[1]); if (focused) { scale = this.styles.info(scale); lines = lines.map(line => this.styles.info(line)); } lines[0] += scale; if (this.linebreak) lines.push(''); return [ind + pointer, lines.join('\n')].filter(Boolean); } async renderChoices() { if (this.state.submitted) return ''; this.tableize(); let choices = this.visible.map(async(ch, i) => await this.renderChoice(ch, i)); let visible = await Promise.all(choices); let heading = await this.renderScaleHeading(); return this.margin[0] + [heading, ...visible.map(v => v.join(' '))].join('\n'); } async render() { let { submitted, size } = this.state; let prefix = await this.prefix(); let separator = await this.separator(); let message = await this.message(); let prompt = ''; if (this.options.promptLine !== false) { prompt = [prefix, message, separator, ''].join(' '); this.state.prompt = prompt; } let header = await this.header(); let output = await this.format(); let key = await this.renderScaleKey(); let help = await this.error() || await this.hint(); let body = await this.renderChoices(); let footer = await this.footer(); let err = this.emptyError; if (output) prompt += output; if (help && !prompt.includes(help)) prompt += ' ' + help; if (submitted && !output && !body.trim() && this.multiple && err != null) { prompt += this.styles.danger(err); } this.clear(size); this.write([header, prompt, key, body, footer].filter(Boolean).join('\n')); if (!this.state.submitted) { this.write(this.margin[2]); } this.restore(); } submit() { this.value = {}; for (let choice of this.choices) { this.value[choice.name] = choice.scaleIndex; } return this.base.submit.call(this); } } module.exports = LikertScale; /***/ }), /***/ 13466: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { "use strict"; const ArrayPrompt = __webpack_require__(98575); const utils = __webpack_require__(83546); class SelectPrompt extends ArrayPrompt { constructor(options) { super(options); this.emptyError = this.options.emptyError || 'No items were selected'; } async dispatch(s, key) { if (this.multiple) { return this[key.name] ? await this[key.name](s, key) : await super.dispatch(s, key); } this.alert(); } separator() { if (this.options.separator) return super.separator(); let sep = this.styles.muted(this.symbols.ellipsis); return this.state.submitted ? super.separator() : sep; } pointer(choice, i) { return (!this.multiple || this.options.pointer) ? super.pointer(choice, i) : ''; } indicator(choice, i) { return this.multiple ? super.indicator(choice, i) : ''; } choiceMessage(choice, i) { let message = this.resolve(choice.message, this.state, choice, i); if (choice.role === 'heading' && !utils.hasColor(message)) { message = this.styles.strong(message); } return this.resolve(message, this.state, choice, i); } choiceSeparator() { return ':'; } async renderChoice(choice, i) { await this.onChoice(choice, i); let focused = this.index === i; let pointer = await this.pointer(choice, i); let check = await this.indicator(choice, i) + (choice.pad || ''); let hint = await this.resolve(choice.hint, this.state, choice, i); if (hint && !utils.hasColor(hint)) { hint = this.styles.muted(hint); } let ind = this.indent(choice); let msg = await this.choiceMessage(choice, i); let line = () => [this.margin[3], ind + pointer + check, msg, this.margin[1], hint].filter(Boolean).join(' '); if (choice.role === 'heading') { return line(); } if (choice.disabled) { if (!utils.hasColor(msg)) { msg = this.styles.disabled(msg); } return line(); } if (focused) { msg = this.styles.em(msg); } return line(); } async renderChoices() { if (this.state.loading === 'choices') { return this.styles.warning('Loading choices'); } if (this.state.submitted) return ''; let choices = this.visible.map(async(ch, i) => await this.renderChoice(ch, i)); let visible = await Promise.all(choices); if (!visible.length) visible.push(this.styles.danger('No matching choices')); let result = this.margin[0] + visible.join('\n'); let header; if (this.options.choicesHeader) { header = await this.resolve(this.options.choicesHeader, this.state); } return [header, result].filter(Boolean).join('\n'); } format() { if (!this.state.submitted || this.state.cancelled) return ''; if (Array.isArray(this.selected)) { return this.selected.map(choice => this.styles.primary(choice.name)).join(', '); } return this.styles.primary(this.selected.name); } async render() { let { submitted, size } = this.state; let prompt = ''; let header = await this.header(); let prefix = await this.prefix(); let separator = await this.separator(); let message = await this.message(); if (this.options.promptLine !== false) { prompt = [prefix, message, separator, ''].join(' '); this.state.prompt = prompt; } let output = await this.format(); let help = (await this.error()) || (await this.hint()); let body = await this.renderChoices(); let footer = await this.footer(); if (output) prompt += output; if (help && !prompt.includes(help)) prompt += ' ' + help; if (submitted && !output && !body.trim() && this.multiple && this.emptyError != null) { prompt += this.styles.danger(this.emptyError); } this.clear(size); this.write([header, prompt, body, footer].filter(Boolean).join('\n')); this.write(this.margin[2]); this.restore(); } } module.exports = SelectPrompt; /***/ }), /***/ 19451: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { "use strict"; const colors = __webpack_require__(53692); const interpolate = __webpack_require__(27189); const Prompt = __webpack_require__(232); class SnippetPrompt extends Prompt { constructor(options) { super(options); this.cursorHide(); this.reset(true); } async initialize() { this.interpolate = await interpolate(this); await super.initialize(); } async reset(first) { this.state.keys = []; this.state.invalid = new Map(); this.state.missing = new Set(); this.state.completed = 0; this.state.values = {}; if (first !== true) { await this.initialize(); await this.render(); } } moveCursor(n) { let item = this.getItem(); this.cursor += n; item.cursor += n; } dispatch(ch, key) { if (!key.code && !key.ctrl && ch != null && this.getItem()) { this.append(ch, key); return; } this.alert(); } append(ch, key) { let item = this.getItem(); let prefix = item.input.slice(0, this.cursor); let suffix = item.input.slice(this.cursor); this.input = item.input = `${prefix}${ch}${suffix}`; this.moveCursor(1); this.render(); } delete() { let item = this.getItem(); if (this.cursor <= 0 || !item.input) return this.alert(); let suffix = item.input.slice(this.cursor); let prefix = item.input.slice(0, this.cursor - 1); this.input = item.input = `${prefix}${suffix}`; this.moveCursor(-1); this.render(); } increment(i) { return i >= this.state.keys.length - 1 ? 0 : i + 1; } decrement(i) { return i <= 0 ? this.state.keys.length - 1 : i - 1; } first() { this.state.index = 0; this.render(); } last() { this.state.index = this.state.keys.length - 1; this.render(); } right() { if (this.cursor >= this.input.length) return this.alert(); this.moveCursor(1); this.render(); } left() { if (this.cursor <= 0) return this.alert(); this.moveCursor(-1); this.render(); } prev() { this.state.index = this.decrement(this.state.index); this.getItem(); this.render(); } next() { this.state.index = this.increment(this.state.index); this.getItem(); this.render(); } up() { this.prev(); } down() { this.next(); } format(value) { let color = this.state.completed < 100 ? this.styles.warning : this.styles.success; if (this.state.submitted === true && this.state.completed !== 100) { color = this.styles.danger; } return color(`${this.state.completed}% completed`); } async render() { let { index, keys = [], submitted, size } = this.state; let newline = [this.options.newline, '\n'].find(v => v != null); let prefix = await this.prefix(); let separator = await this.separator(); let message = await this.message(); let prompt = [prefix, message, separator].filter(Boolean).join(' '); this.state.prompt = prompt; let header = await this.header(); let error = (await this.error()) || ''; let hint = (await this.hint()) || ''; let body = submitted ? '' : await this.interpolate(this.state); let key = this.state.key = keys[index] || ''; let input = await this.format(key); let footer = await this.footer(); if (input) prompt += ' ' + input; if (hint && !input && this.state.completed === 0) prompt += ' ' + hint; this.clear(size); let lines = [header, prompt, body, footer, error.trim()]; this.write(lines.filter(Boolean).join(newline)); this.restore(); } getItem(name) { let { items, keys, index } = this.state; let item = items.find(ch => ch.name === keys[index]); if (item && item.input != null) { this.input = item.input; this.cursor = item.cursor; } return item; } async submit() { if (typeof this.interpolate !== 'function') await this.initialize(); await this.interpolate(this.state, true); let { invalid, missing, output, values } = this.state; if (invalid.size) { let err = ''; for (let [key, value] of invalid) err += `Invalid ${key}: ${value}\n`; this.state.error = err; return super.submit(); } if (missing.size) { this.state.error = 'Required: ' + [...missing.keys()].join(', '); return super.submit(); } let lines = colors.unstyle(output).split('\n'); let result = lines.map(v => v.slice(1)).join('\n'); this.value = { values, result }; return super.submit(); } } module.exports = SnippetPrompt; /***/ }), /***/ 7144: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { "use strict"; const hint = '(Use + to sort)'; const Prompt = __webpack_require__(13466); class Sort extends Prompt { constructor(options) { super({ ...options, reorder: false, sort: true, multiple: true }); this.state.hint = [this.options.hint, hint].find(this.isValue.bind(this)); } indicator() { return ''; } async renderChoice(choice, i) { let str = await super.renderChoice(choice, i); let sym = this.symbols.identicalTo + ' '; let pre = (this.index === i && this.sorting) ? this.styles.muted(sym) : ' '; if (this.options.drag === false) pre = ''; if (this.options.numbered === true) { return pre + `${i + 1} - ` + str; } return pre + str; } get selected() { return this.choices; } submit() { this.value = this.choices.map(choice => choice.value); return super.submit(); } } module.exports = Sort; /***/ }), /***/ 83755: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { "use strict"; const ArrayPrompt = __webpack_require__(98575); class Survey extends ArrayPrompt { constructor(options = {}) { super(options); this.emptyError = options.emptyError || 'No items were selected'; this.term = process.env.TERM_PROGRAM; if (!this.options.header) { let header = ['', '4 - Strongly Agree', '3 - Agree', '2 - Neutral', '1 - Disagree', '0 - Strongly Disagree', '']; header = header.map(ele => this.styles.muted(ele)); this.state.header = header.join('\n '); } } async toChoices(...args) { if (this.createdScales) return false; this.createdScales = true; let choices = await super.toChoices(...args); for (let choice of choices) { choice.scale = createScale(5, this.options); choice.scaleIdx = 2; } return choices; } dispatch() { this.alert(); } space() { let choice = this.focused; let ele = choice.scale[choice.scaleIdx]; let selected = ele.selected; choice.scale.forEach(e => (e.selected = false)); ele.selected = !selected; return this.render(); } indicator() { return ''; } pointer() { return ''; } separator() { return this.styles.muted(this.symbols.ellipsis); } right() { let choice = this.focused; if (choice.scaleIdx >= choice.scale.length - 1) return this.alert(); choice.scaleIdx++; return this.render(); } left() { let choice = this.focused; if (choice.scaleIdx <= 0) return this.alert(); choice.scaleIdx--; return this.render(); } indent() { return ' '; } async renderChoice(item, i) { await this.onChoice(item, i); let focused = this.index === i; let isHyper = this.term === 'Hyper'; let n = !isHyper ? 8 : 9; let s = !isHyper ? ' ' : ''; let ln = this.symbols.line.repeat(n); let sp = ' '.repeat(n + (isHyper ? 0 : 1)); let dot = enabled => (enabled ? this.styles.success('◉') : '◯') + s; let num = i + 1 + '.'; let color = focused ? this.styles.heading : this.styles.noop; let msg = await this.resolve(item.message, this.state, item, i); let indent = this.indent(item); let scale = indent + item.scale.map((e, i) => dot(i === item.scaleIdx)).join(ln); let val = i => i === item.scaleIdx ? color(i) : i; let next = indent + item.scale.map((e, i) => val(i)).join(sp); let line = () => [num, msg].filter(Boolean).join(' '); let lines = () => [line(), scale, next, ' '].filter(Boolean).join('\n'); if (focused) { scale = this.styles.cyan(scale); next = this.styles.cyan(next); } return lines(); } async renderChoices() { if (this.state.submitted) return ''; let choices = this.visible.map(async(ch, i) => await this.renderChoice(ch, i)); let visible = await Promise.all(choices); if (!visible.length) visible.push(this.styles.danger('No matching choices')); return visible.join('\n'); } format() { if (this.state.submitted) { let values = this.choices.map(ch => this.styles.info(ch.scaleIdx)); return values.join(', '); } return ''; } async render() { let { submitted, size } = this.state; let prefix = await this.prefix(); let separator = await this.separator(); let message = await this.message(); let prompt = [prefix, message, separator].filter(Boolean).join(' '); this.state.prompt = prompt; let header = await this.header(); let output = await this.format(); let help = await this.error() || await this.hint(); let body = await this.renderChoices(); let footer = await this.footer(); if (output || !help) prompt += ' ' + output; if (help && !prompt.includes(help)) prompt += ' ' + help; if (submitted && !output && !body && this.multiple && this.type !== 'form') { prompt += this.styles.danger(this.emptyError); } this.clear(size); this.write([prompt, header, body, footer].filter(Boolean).join('\n')); this.restore(); } submit() { this.value = {}; for (let choice of this.choices) { this.value[choice.name] = choice.scaleIdx; } return this.base.submit.call(this); } } function createScale(n, options = {}) { if (Array.isArray(options.scale)) { return options.scale.map(ele => ({ ...ele })); } let scale = []; for (let i = 1; i < n + 1; i++) scale.push({ i, selected: false }); return scale; } module.exports = Survey; /***/ }), /***/ 5781: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { module.exports = __webpack_require__(66719); /***/ }), /***/ 10653: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { "use strict"; const BooleanPrompt = __webpack_require__(23838); class TogglePrompt extends BooleanPrompt { async initialize() { await super.initialize(); this.value = this.initial = !!this.options.initial; this.disabled = this.options.disabled || 'no'; this.enabled = this.options.enabled || 'yes'; await this.render(); } reset() { this.value = this.initial; this.render(); } delete() { this.alert(); } toggle() { this.value = !this.value; this.render(); } enable() { if (this.value === true) return this.alert(); this.value = true; this.render(); } disable() { if (this.value === false) return this.alert(); this.value = false; this.render(); } up() { this.toggle(); } down() { this.toggle(); } right() { this.toggle(); } left() { this.toggle(); } next() { this.toggle(); } prev() { this.toggle(); } dispatch(ch = '', key) { switch (ch.toLowerCase()) { case ' ': return this.toggle(); case '1': case 'y': case 't': return this.enable(); case '0': case 'n': case 'f': return this.disable(); default: { return this.alert(); } } } format() { let active = str => this.styles.primary.underline(str); let value = [ this.value ? this.disabled : active(this.disabled), this.value ? active(this.enabled) : this.enabled ]; return value.join(this.styles.muted(' / ')); } async render() { let { size } = this.state; let header = await this.header(); let prefix = await this.prefix(); let separator = await this.separator(); let message = await this.message(); let output = await this.format(); let help = (await this.error()) || (await this.hint()); let footer = await this.footer(); let prompt = [prefix, message, separator, output].join(' '); this.state.prompt = prompt; if (help && !prompt.includes(help)) prompt += ' ' + help; this.clear(size); this.write([header, prompt, footer].filter(Boolean).join('\n')); this.write(this.margin[2]); this.restore(); } } module.exports = TogglePrompt; /***/ }), /***/ 31502: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { "use strict"; const utils = __webpack_require__(83546); const roles = { default(prompt, choice) { return choice; }, checkbox(prompt, choice) { throw new Error('checkbox role is not implemented yet'); }, editable(prompt, choice) { throw new Error('editable role is not implemented yet'); }, expandable(prompt, choice) { throw new Error('expandable role is not implemented yet'); }, heading(prompt, choice) { choice.disabled = ''; choice.indicator = [choice.indicator, ' '].find(v => v != null); choice.message = choice.message || ''; return choice; }, input(prompt, choice) { throw new Error('input role is not implemented yet'); }, option(prompt, choice) { return roles.default(prompt, choice); }, radio(prompt, choice) { throw new Error('radio role is not implemented yet'); }, separator(prompt, choice) { choice.disabled = ''; choice.indicator = [choice.indicator, ' '].find(v => v != null); choice.message = choice.message || prompt.symbols.line.repeat(5); return choice; }, spacer(prompt, choice) { return choice; } }; module.exports = (name, options = {}) => { let role = utils.merge({}, roles, options.roles); return role[name] || role.default; }; /***/ }), /***/ 36873: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { "use strict"; const { define, width } = __webpack_require__(83546); class State { constructor(prompt) { let options = prompt.options; define(this, '_prompt', prompt); this.type = prompt.type; this.name = prompt.name; this.message = ''; this.header = ''; this.footer = ''; this.error = ''; this.hint = ''; this.input = ''; this.cursor = 0; this.index = 0; this.lines = 0; this.tick = 0; this.prompt = ''; this.buffer = ''; this.width = width(options.stdout || process.stdout); Object.assign(this, options); this.name = this.name || this.message; this.message = this.message || this.name; this.symbols = prompt.symbols; this.styles = prompt.styles; this.required = new Set(); this.cancelled = false; this.submitted = false; } clone() { let state = { ...this }; state.status = this.status; state.buffer = Buffer.from(state.buffer); delete state.clone; return state; } set color(val) { this._color = val; } get color() { let styles = this.prompt.styles; if (this.cancelled) return styles.cancelled; if (this.submitted) return styles.submitted; let color = this._color || styles[this.status]; return typeof color === 'function' ? color : styles.pending; } set loading(value) { this._loading = value; } get loading() { if (typeof this._loading === 'boolean') return this._loading; if (this.loadingChoices) return 'choices'; return false; } get status() { if (this.cancelled) return 'cancelled'; if (this.submitted) return 'submitted'; return 'pending'; } } module.exports = State; /***/ }), /***/ 79217: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { "use strict"; const utils = __webpack_require__(83546); const colors = __webpack_require__(53692); const styles = { default: colors.noop, noop: colors.noop, /** * Modifiers */ set inverse(custom) { this._inverse = custom; }, get inverse() { return this._inverse || utils.inverse(this.primary); }, set complement(custom) { this._complement = custom; }, get complement() { return this._complement || utils.complement(this.primary); }, /** * Main color */ primary: colors.cyan, /** * Main palette */ success: colors.green, danger: colors.magenta, strong: colors.bold, warning: colors.yellow, muted: colors.dim, disabled: colors.gray, dark: colors.dim.gray, underline: colors.underline, set info(custom) { this._info = custom; }, get info() { return this._info || this.primary; }, set em(custom) { this._em = custom; }, get em() { return this._em || this.primary.underline; }, set heading(custom) { this._heading = custom; }, get heading() { return this._heading || this.muted.underline; }, /** * Statuses */ set pending(custom) { this._pending = custom; }, get pending() { return this._pending || this.primary; }, set submitted(custom) { this._submitted = custom; }, get submitted() { return this._submitted || this.success; }, set cancelled(custom) { this._cancelled = custom; }, get cancelled() { return this._cancelled || this.danger; }, /** * Special styling */ set typing(custom) { this._typing = custom; }, get typing() { return this._typing || this.dim; }, set placeholder(custom) { this._placeholder = custom; }, get placeholder() { return this._placeholder || this.primary.dim; }, set highlight(custom) { this._highlight = custom; }, get highlight() { return this._highlight || this.inverse; } }; styles.merge = (options = {}) => { if (options.styles && typeof options.styles.enabled === 'boolean') { colors.enabled = options.styles.enabled; } if (options.styles && typeof options.styles.visible === 'boolean') { colors.visible = options.styles.visible; } let result = utils.merge({}, styles, options.styles); delete result.merge; for (let key of Object.keys(colors)) { if (!result.hasOwnProperty(key)) { Reflect.defineProperty(result, key, { get: () => colors[key] }); } } for (let key of Object.keys(colors.styles)) { if (!result.hasOwnProperty(key)) { Reflect.defineProperty(result, key, { get: () => colors[key] }); } } return result; }; module.exports = styles; /***/ }), /***/ 74739: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { "use strict"; const isWindows = process.platform === 'win32'; const colors = __webpack_require__(53692); const utils = __webpack_require__(83546); const symbols = { ...colors.symbols, upDownDoubleArrow: '⇕', upDownDoubleArrow2: '⬍', upDownArrow: '↕', asterisk: '*', asterism: '⁂', bulletWhite: '◦', electricArrow: '⌁', ellipsisLarge: '⋯', ellipsisSmall: '…', fullBlock: '█', identicalTo: '≡', indicator: colors.symbols.check, leftAngle: '‹', mark: '※', minus: '−', multiplication: '×', obelus: '÷', percent: '%', pilcrow: '¶', pilcrow2: '❡', pencilUpRight: '✐', pencilDownRight: '✎', pencilRight: '✏', plus: '+', plusMinus: '±', pointRight: '☞', rightAngle: '›', section: '§', hexagon: { off: '⬡', on: '⬢', disabled: '⬢' }, ballot: { on: '☑', off: '☐', disabled: '☒' }, stars: { on: '★', off: '☆', disabled: '☆' }, folder: { on: '▼', off: '▶', disabled: '▶' }, prefix: { pending: colors.symbols.question, submitted: colors.symbols.check, cancelled: colors.symbols.cross }, separator: { pending: colors.symbols.pointerSmall, submitted: colors.symbols.middot, cancelled: colors.symbols.middot }, radio: { off: isWindows ? '( )' : '◯', on: isWindows ? '(*)' : '◉', disabled: isWindows ? '(|)' : 'Ⓘ' }, numbers: ['⓪', '①', '②', '③', '④', '⑤', '⑥', '⑦', '⑧', '⑨', '⑩', '⑪', '⑫', '⑬', '⑭', '⑮', '⑯', '⑰', '⑱', '⑲', '⑳', '㉑', '㉒', '㉓', '㉔', '㉕', '㉖', '㉗', '㉘', '㉙', '㉚', '㉛', '㉜', '㉝', '㉞', '㉟', '㊱', '㊲', '㊳', '㊴', '㊵', '㊶', '㊷', '㊸', '㊹', '㊺', '㊻', '㊼', '㊽', '㊾', '㊿'] }; symbols.merge = options => { let result = utils.merge({}, colors.symbols, symbols, options.symbols); delete result.merge; return result; }; module.exports = symbols; /***/ }), /***/ 39227: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { "use strict"; const styles = __webpack_require__(79217); const symbols = __webpack_require__(74739); const utils = __webpack_require__(83546); module.exports = prompt => { prompt.options = utils.merge({}, prompt.options.theme, prompt.options); prompt.symbols = symbols.merge(prompt.options); prompt.styles = styles.merge(prompt.options); }; /***/ }), /***/ 33940: /***/ ((module) => { "use strict"; module.exports = prompt => { prompt.timers = prompt.timers || {}; let timers = prompt.options.timers; if (!timers) return; for (let key of Object.keys(timers)) { let opts = timers[key]; if (typeof opts === 'number') { opts = { interval: opts }; } create(prompt, key, opts); } }; function create(prompt, name, options = {}) { let timer = prompt.timers[name] = { name, start: Date.now(), ms: 0, tick: 0 }; let ms = options.interval || 120; timer.frames = options.frames || []; timer.loading = true; let interval = setInterval(() => { timer.ms = Date.now() - timer.start; timer.tick++; prompt.render(); }, ms); timer.stop = () => { timer.loading = false; clearInterval(interval); }; Reflect.defineProperty(timer, 'interval', { value: interval }); prompt.once('close', () => timer.stop()); return timer.stop; } /***/ }), /***/ 98575: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { "use strict"; const colors = __webpack_require__(53692); const Prompt = __webpack_require__(232); const roles = __webpack_require__(31502); const utils = __webpack_require__(83546); const { reorder, scrollUp, scrollDown, isObject, swap } = utils; class ArrayPrompt extends Prompt { constructor(options) { super(options); this.cursorHide(); this.maxSelected = options.maxSelected || Infinity; this.multiple = options.multiple || false; this.initial = options.initial || 0; this.delay = options.delay || 0; this.longest = 0; this.num = ''; } async initialize() { if (typeof this.options.initial === 'function') { this.initial = await this.options.initial.call(this); } await this.reset(true); await super.initialize(); } async reset() { let { choices, initial, autofocus, suggest } = this.options; this.state._choices = []; this.state.choices = []; this.choices = await Promise.all(await this.toChoices(choices)); this.choices.forEach(ch => (ch.enabled = false)); if (typeof suggest !== 'function' && this.selectable.length === 0) { throw new Error('At least one choice must be selectable'); } if (isObject(initial)) initial = Object.keys(initial); if (Array.isArray(initial)) { if (autofocus != null) this.index = this.findIndex(autofocus); initial.forEach(v => this.enable(this.find(v))); await this.render(); } else { if (autofocus != null) initial = autofocus; if (typeof initial === 'string') initial = this.findIndex(initial); if (typeof initial === 'number' && initial > -1) { this.index = Math.max(0, Math.min(initial, this.choices.length)); this.enable(this.find(this.index)); } } if (this.isDisabled(this.focused)) { await this.down(); } } async toChoices(value, parent) { this.state.loadingChoices = true; let choices = []; let index = 0; let toChoices = async(items, parent) => { if (typeof items === 'function') items = await items.call(this); if (items instanceof Promise) items = await items; for (let i = 0; i < items.length; i++) { let choice = items[i] = await this.toChoice(items[i], index++, parent); choices.push(choice); if (choice.choices) { await toChoices(choice.choices, choice); } } return choices; }; return toChoices(value, parent) .then(choices => { this.state.loadingChoices = false; return choices; }); } async toChoice(ele, i, parent) { if (typeof ele === 'function') ele = await ele.call(this, this); if (ele instanceof Promise) ele = await ele; if (typeof ele === 'string') ele = { name: ele }; if (ele.normalized) return ele; ele.normalized = true; let origVal = ele.value; let role = roles(ele.role, this.options); ele = role(this, ele); if (typeof ele.disabled === 'string' && !ele.hint) { ele.hint = ele.disabled; ele.disabled = true; } if (ele.disabled === true && ele.hint == null) { ele.hint = '(disabled)'; } // if the choice was already normalized, return it if (ele.index != null) return ele; ele.name = ele.name || ele.key || ele.title || ele.value || ele.message; ele.message = ele.message || ele.name || ''; ele.value = [ele.value, ele.name].find(this.isValue.bind(this)); ele.input = ''; ele.index = i; ele.cursor = 0; utils.define(ele, 'parent', parent); ele.level = parent ? parent.level + 1 : 1; if (ele.indent == null) { ele.indent = parent ? parent.indent + ' ' : (ele.indent || ''); } ele.path = parent ? parent.path + '.' + ele.name : ele.name; ele.enabled = !!(this.multiple && !this.isDisabled(ele) && (ele.enabled || this.isSelected(ele))); if (!this.isDisabled(ele)) { this.longest = Math.max(this.longest, colors.unstyle(ele.message).length); } // shallow clone the choice first let choice = { ...ele }; // then allow the choice to be reset using the "original" values ele.reset = (input = choice.input, value = choice.value) => { for (let key of Object.keys(choice)) ele[key] = choice[key]; ele.input = input; ele.value = value; }; if (origVal == null && typeof ele.initial === 'function') { ele.input = await ele.initial.call(this, this.state, ele, i); } return ele; } async onChoice(choice, i) { this.emit('choice', choice, i, this); if (typeof choice.onChoice === 'function') { await choice.onChoice.call(this, this.state, choice, i); } } async addChoice(ele, i, parent) { let choice = await this.toChoice(ele, i, parent); this.choices.push(choice); this.index = this.choices.length - 1; this.limit = this.choices.length; return choice; } async newItem(item, i, parent) { let ele = { name: 'New choice name?', editable: true, newChoice: true, ...item }; let choice = await this.addChoice(ele, i, parent); choice.updateChoice = () => { delete choice.newChoice; choice.name = choice.message = choice.input; choice.input = ''; choice.cursor = 0; }; return this.render(); } indent(choice) { if (choice.indent == null) { return choice.level > 1 ? ' '.repeat(choice.level - 1) : ''; } return choice.indent; } dispatch(s, key) { if (this.multiple && this[key.name]) return this[key.name](); this.alert(); } focus(choice, enabled) { if (typeof enabled !== 'boolean') enabled = choice.enabled; if (enabled && !choice.enabled && this.selected.length >= this.maxSelected) { return this.alert(); } this.index = choice.index; choice.enabled = enabled && !this.isDisabled(choice); return choice; } space() { if (!this.multiple) return this.alert(); this.toggle(this.focused); return this.render(); } a() { if (this.maxSelected < this.choices.length) return this.alert(); let enabled = this.selectable.every(ch => ch.enabled); this.choices.forEach(ch => (ch.enabled = !enabled)); return this.render(); } i() { // don't allow choices to be inverted if it will result in // more than the maximum number of allowed selected items. if (this.choices.length - this.selected.length > this.maxSelected) { return this.alert(); } this.choices.forEach(ch => (ch.enabled = !ch.enabled)); return this.render(); } g(choice = this.focused) { if (!this.choices.some(ch => !!ch.parent)) return this.a(); this.toggle((choice.parent && !choice.choices) ? choice.parent : choice); return this.render(); } toggle(choice, enabled) { if (!choice.enabled && this.selected.length >= this.maxSelected) { return this.alert(); } if (typeof enabled !== 'boolean') enabled = !choice.enabled; choice.enabled = enabled; if (choice.choices) { choice.choices.forEach(ch => this.toggle(ch, enabled)); } let parent = choice.parent; while (parent) { let choices = parent.choices.filter(ch => this.isDisabled(ch)); parent.enabled = choices.every(ch => ch.enabled === true); parent = parent.parent; } reset(this, this.choices); this.emit('toggle', choice, this); return choice; } enable(choice) { if (this.selected.length >= this.maxSelected) return this.alert(); choice.enabled = !this.isDisabled(choice); choice.choices && choice.choices.forEach(this.enable.bind(this)); return choice; } disable(choice) { choice.enabled = false; choice.choices && choice.choices.forEach(this.disable.bind(this)); return choice; } number(n) { this.num += n; let number = num => { let i = Number(num); if (i > this.choices.length - 1) return this.alert(); let focused = this.focused; let choice = this.choices.find(ch => i === ch.index); if (!choice.enabled && this.selected.length >= this.maxSelected) { return this.alert(); } if (this.visible.indexOf(choice) === -1) { let choices = reorder(this.choices); let actualIdx = choices.indexOf(choice); if (focused.index > actualIdx) { let start = choices.slice(actualIdx, actualIdx + this.limit); let end = choices.filter(ch => !start.includes(ch)); this.choices = start.concat(end); } else { let pos = actualIdx - this.limit + 1; this.choices = choices.slice(pos).concat(choices.slice(0, pos)); } } this.index = this.choices.indexOf(choice); this.toggle(this.focused); return this.render(); }; clearTimeout(this.numberTimeout); return new Promise(resolve => { let len = this.choices.length; let num = this.num; let handle = (val = false, res) => { clearTimeout(this.numberTimeout); if (val) res = number(num); this.num = ''; resolve(res); }; if (num === '0' || (num.length === 1 && Number(num + '0') > len)) { return handle(true); } if (Number(num) > len) { return handle(false, this.alert()); } this.numberTimeout = setTimeout(() => handle(true), this.delay); }); } home() { this.choices = reorder(this.choices); this.index = 0; return this.render(); } end() { let pos = this.choices.length - this.limit; let choices = reorder(this.choices); this.choices = choices.slice(pos).concat(choices.slice(0, pos)); this.index = this.limit - 1; return this.render(); } first() { this.index = 0; return this.render(); } last() { this.index = this.visible.length - 1; return this.render(); } prev() { if (this.visible.length <= 1) return this.alert(); return this.up(); } next() { if (this.visible.length <= 1) return this.alert(); return this.down(); } right() { if (this.cursor >= this.input.length) return this.alert(); this.cursor++; return this.render(); } left() { if (this.cursor <= 0) return this.alert(); this.cursor--; return this.render(); } up() { let len = this.choices.length; let vis = this.visible.length; let idx = this.index; if (this.options.scroll === false && idx === 0) { return this.alert(); } if (len > vis && idx === 0) { return this.scrollUp(); } this.index = ((idx - 1 % len) + len) % len; if (this.isDisabled()) { return this.up(); } return this.render(); } down() { let len = this.choices.length; let vis = this.visible.length; let idx = this.index; if (this.options.scroll === false && idx === vis - 1) { return this.alert(); } if (len > vis && idx === vis - 1) { return this.scrollDown(); } this.index = (idx + 1) % len; if (this.isDisabled()) { return this.down(); } return this.render(); } scrollUp(i = 0) { this.choices = scrollUp(this.choices); this.index = i; if (this.isDisabled()) { return this.up(); } return this.render(); } scrollDown(i = this.visible.length - 1) { this.choices = scrollDown(this.choices); this.index = i; if (this.isDisabled()) { return this.down(); } return this.render(); } async shiftUp() { if (this.options.sort === true) { this.sorting = true; this.swap(this.index - 1); await this.up(); this.sorting = false; return; } return this.scrollUp(this.index); } async shiftDown() { if (this.options.sort === true) { this.sorting = true; this.swap(this.index + 1); await this.down(); this.sorting = false; return; } return this.scrollDown(this.index); } pageUp() { if (this.visible.length <= 1) return this.alert(); this.limit = Math.max(this.limit - 1, 0); this.index = Math.min(this.limit - 1, this.index); this._limit = this.limit; if (this.isDisabled()) { return this.up(); } return this.render(); } pageDown() { if (this.visible.length >= this.choices.length) return this.alert(); this.index = Math.max(0, this.index); this.limit = Math.min(this.limit + 1, this.choices.length); this._limit = this.limit; if (this.isDisabled()) { return this.down(); } return this.render(); } swap(pos) { swap(this.choices, this.index, pos); } isDisabled(choice = this.focused) { let keys = ['disabled', 'collapsed', 'hidden', 'completing', 'readonly']; if (choice && keys.some(key => choice[key] === true)) { return true; } return choice && choice.role === 'heading'; } isEnabled(choice = this.focused) { if (Array.isArray(choice)) return choice.every(ch => this.isEnabled(ch)); if (choice.choices) { let choices = choice.choices.filter(ch => !this.isDisabled(ch)); return choice.enabled && choices.every(ch => this.isEnabled(ch)); } return choice.enabled && !this.isDisabled(choice); } isChoice(choice, value) { return choice.name === value || choice.index === Number(value); } isSelected(choice) { if (Array.isArray(this.initial)) { return this.initial.some(value => this.isChoice(choice, value)); } return this.isChoice(choice, this.initial); } map(names = [], prop = 'value') { return [].concat(names || []).reduce((acc, name) => { acc[name] = this.find(name, prop); return acc; }, {}); } filter(value, prop) { let isChoice = (ele, i) => [ele.name, i].includes(value); let fn = typeof value === 'function' ? value : isChoice; let choices = this.options.multiple ? this.state._choices : this.choices; let result = choices.filter(fn); if (prop) { return result.map(ch => ch[prop]); } return result; } find(value, prop) { if (isObject(value)) return prop ? value[prop] : value; let isChoice = (ele, i) => [ele.name, i].includes(value); let fn = typeof value === 'function' ? value : isChoice; let choice = this.choices.find(fn); if (choice) { return prop ? choice[prop] : choice; } } findIndex(value) { return this.choices.indexOf(this.find(value)); } async submit() { let choice = this.focused; if (!choice) return this.alert(); if (choice.newChoice) { if (!choice.input) return this.alert(); choice.updateChoice(); return this.render(); } if (this.choices.some(ch => ch.newChoice)) { return this.alert(); } let { reorder, sort } = this.options; let multi = this.multiple === true; let value = this.selected; if (value === void 0) { return this.alert(); } // re-sort choices to original order if (Array.isArray(value) && reorder !== false && sort !== true) { value = utils.reorder(value); } this.value = multi ? value.map(ch => ch.name) : value.name; return super.submit(); } set choices(choices = []) { this.state._choices = this.state._choices || []; this.state.choices = choices; for (let choice of choices) { if (!this.state._choices.some(ch => ch.name === choice.name)) { this.state._choices.push(choice); } } if (!this._initial && this.options.initial) { this._initial = true; let init = this.initial; if (typeof init === 'string' || typeof init === 'number') { let choice = this.find(init); if (choice) { this.initial = choice.index; this.focus(choice, true); } } } } get choices() { return reset(this, this.state.choices || []); } set visible(visible) { this.state.visible = visible; } get visible() { return (this.state.visible || this.choices).slice(0, this.limit); } set limit(num) { this.state.limit = num; } get limit() { let { state, options, choices } = this; let limit = state.limit || this._limit || options.limit || choices.length; return Math.min(limit, this.height); } set value(value) { super.value = value; } get value() { if (typeof super.value !== 'string' && super.value === this.initial) { return this.input; } return super.value; } set index(i) { this.state.index = i; } get index() { return Math.max(0, this.state ? this.state.index : 0); } get enabled() { return this.filter(this.isEnabled.bind(this)); } get focused() { let choice = this.choices[this.index]; if (choice && this.state.submitted && this.multiple !== true) { choice.enabled = true; } return choice; } get selectable() { return this.choices.filter(choice => !this.isDisabled(choice)); } get selected() { return this.multiple ? this.enabled : this.focused; } } function reset(prompt, choices) { if (choices instanceof Promise) return choices; if (typeof choices === 'function') { if (utils.isAsyncFn(choices)) return choices; choices = choices.call(prompt, prompt); } for (let choice of choices) { if (Array.isArray(choice.choices)) { let items = choice.choices.filter(ch => !prompt.isDisabled(ch)); choice.enabled = items.every(ch => ch.enabled === true); } if (prompt.isDisabled(choice) === true) { delete choice.enabled; } } return choices; } module.exports = ArrayPrompt; /***/ }), /***/ 66926: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { "use strict"; const FormPrompt = __webpack_require__(21826); const defaultAuthenticate = () => { throw new Error('expected prompt to have a custom authenticate method'); }; const factory = (authenticate = defaultAuthenticate) => { class AuthPrompt extends FormPrompt { constructor(options) { super(options); } async submit() { this.value = await authenticate.call(this, this.values, this.state); super.base.submit.call(this); } static create(authenticate) { return factory(authenticate); } } return AuthPrompt; }; module.exports = factory(); /***/ }), /***/ 23838: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { "use strict"; const Prompt = __webpack_require__(232); const { isPrimitive, hasColor } = __webpack_require__(83546); class BooleanPrompt extends Prompt { constructor(options) { super(options); this.cursorHide(); } async initialize() { let initial = await this.resolve(this.initial, this.state); this.input = await this.cast(initial); await super.initialize(); } dispatch(ch) { if (!this.isValue(ch)) return this.alert(); this.input = ch; return this.submit(); } format(value) { let { styles, state } = this; return !state.submitted ? styles.primary(value) : styles.success(value); } cast(input) { return this.isTrue(input); } isTrue(input) { return /^[ty1]/i.test(input); } isFalse(input) { return /^[fn0]/i.test(input); } isValue(value) { return isPrimitive(value) && (this.isTrue(value) || this.isFalse(value)); } async hint() { if (this.state.status === 'pending') { let hint = await this.element('hint'); if (!hasColor(hint)) { return this.styles.muted(hint); } return hint; } } async render() { let { input, size } = this.state; let prefix = await this.prefix(); let sep = await this.separator(); let msg = await this.message(); let hint = this.styles.muted(this.default); let promptLine = [prefix, msg, hint, sep].filter(Boolean).join(' '); this.state.prompt = promptLine; let header = await this.header(); let value = this.value = this.cast(input); let output = await this.format(value); let help = (await this.error()) || (await this.hint()); let footer = await this.footer(); if (help && !promptLine.includes(help)) output += ' ' + help; promptLine += ' ' + output; this.clear(size); this.write([header, promptLine, footer].filter(Boolean).join('\n')); this.restore(); } set value(value) { super.value = value; } get value() { return this.cast(super.value); } } module.exports = BooleanPrompt; /***/ }), /***/ 29920: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { module.exports = { ArrayPrompt: __webpack_require__(98575), AuthPrompt: __webpack_require__(66926), BooleanPrompt: __webpack_require__(23838), NumberPrompt: __webpack_require__(45376), StringPrompt: __webpack_require__(43391) }; /***/ }), /***/ 45376: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { "use strict"; const StringPrompt = __webpack_require__(43391); class NumberPrompt extends StringPrompt { constructor(options = {}) { super({ style: 'number', ...options }); this.min = this.isValue(options.min) ? this.toNumber(options.min) : -Infinity; this.max = this.isValue(options.max) ? this.toNumber(options.max) : Infinity; this.delay = options.delay != null ? options.delay : 1000; this.float = options.float !== false; this.round = options.round === true || options.float === false; this.major = options.major || 10; this.minor = options.minor || 1; this.initial = options.initial != null ? options.initial : ''; this.input = String(this.initial); this.cursor = this.input.length; this.cursorShow(); } append(ch) { if (!/[-+.]/.test(ch) || (ch === '.' && this.input.includes('.'))) { return this.alert('invalid number'); } return super.append(ch); } number(ch) { return super.append(ch); } next() { if (this.input && this.input !== this.initial) return this.alert(); if (!this.isValue(this.initial)) return this.alert(); this.input = this.initial; this.cursor = String(this.initial).length; return this.render(); } up(number) { let step = number || this.minor; let num = this.toNumber(this.input); if (num > this.max + step) return this.alert(); this.input = `${num + step}`; return this.render(); } down(number) { let step = number || this.minor; let num = this.toNumber(this.input); if (num < this.min - step) return this.alert(); this.input = `${num - step}`; return this.render(); } shiftDown() { return this.down(this.major); } shiftUp() { return this.up(this.major); } format(input = this.input) { if (typeof this.options.format === 'function') { return this.options.format.call(this, input); } return this.styles.info(input); } toNumber(value = '') { return this.float ? +value : Math.round(+value); } isValue(value) { return /^[-+]?[0-9]+((\.)|(\.[0-9]+))?$/.test(value); } submit() { let value = [this.input, this.initial].find(v => this.isValue(v)); this.value = this.toNumber(value || 0); return super.submit(); } } module.exports = NumberPrompt; /***/ }), /***/ 43391: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { "use strict"; const Prompt = __webpack_require__(232); const placeholder = __webpack_require__(12786); const { isPrimitive } = __webpack_require__(83546); class StringPrompt extends Prompt { constructor(options) { super(options); this.initial = isPrimitive(this.initial) ? String(this.initial) : ''; if (this.initial) this.cursorHide(); this.state.prevCursor = 0; this.state.clipboard = []; } async keypress(input, key = {}) { let prev = this.state.prevKeypress; this.state.prevKeypress = key; if (this.options.multiline === true && key.name === 'return') { if (!prev || prev.name !== 'return') { return this.append('\n', key); } } return super.keypress(input, key); } moveCursor(n) { this.cursor += n; } reset() { this.input = this.value = ''; this.cursor = 0; return this.render(); } dispatch(ch, key) { if (!ch || key.ctrl || key.code) return this.alert(); this.append(ch); } append(ch) { let { cursor, input } = this.state; this.input = `${input}`.slice(0, cursor) + ch + `${input}`.slice(cursor); this.moveCursor(String(ch).length); this.render(); } insert(str) { this.append(str); } delete() { let { cursor, input } = this.state; if (cursor <= 0) return this.alert(); this.input = `${input}`.slice(0, cursor - 1) + `${input}`.slice(cursor); this.moveCursor(-1); this.render(); } deleteForward() { let { cursor, input } = this.state; if (input[cursor] === void 0) return this.alert(); this.input = `${input}`.slice(0, cursor) + `${input}`.slice(cursor + 1); this.render(); } cutForward() { let pos = this.cursor; if (this.input.length <= pos) return this.alert(); this.state.clipboard.push(this.input.slice(pos)); this.input = this.input.slice(0, pos); this.render(); } cutLeft() { let pos = this.cursor; if (pos === 0) return this.alert(); let before = this.input.slice(0, pos); let after = this.input.slice(pos); let words = before.split(' '); this.state.clipboard.push(words.pop()); this.input = words.join(' '); this.cursor = this.input.length; this.input += after; this.render(); } paste() { if (!this.state.clipboard.length) return this.alert(); this.insert(this.state.clipboard.pop()); this.render(); } toggleCursor() { if (this.state.prevCursor) { this.cursor = this.state.prevCursor; this.state.prevCursor = 0; } else { this.state.prevCursor = this.cursor; this.cursor = 0; } this.render(); } first() { this.cursor = 0; this.render(); } last() { this.cursor = this.input.length - 1; this.render(); } next() { let init = this.initial != null ? String(this.initial) : ''; if (!init || !init.startsWith(this.input)) return this.alert(); this.input = this.initial; this.cursor = this.initial.length; this.render(); } prev() { if (!this.input) return this.alert(); this.reset(); } backward() { return this.left(); } forward() { return this.right(); } right() { if (this.cursor >= this.input.length) return this.alert(); this.moveCursor(1); return this.render(); } left() { if (this.cursor <= 0) return this.alert(); this.moveCursor(-1); return this.render(); } isValue(value) { return !!value; } async format(input = this.value) { let initial = await this.resolve(this.initial, this.state); if (!this.state.submitted) { return placeholder(this, { input, initial, pos: this.cursor }); } return this.styles.submitted(input || initial); } async render() { let size = this.state.size; let prefix = await this.prefix(); let separator = await this.separator(); let message = await this.message(); let prompt = [prefix, message, separator].filter(Boolean).join(' '); this.state.prompt = prompt; let header = await this.header(); let output = await this.format(); let help = (await this.error()) || (await this.hint()); let footer = await this.footer(); if (help && !output.includes(help)) output += ' ' + help; prompt += ' ' + output; this.clear(size); this.write([header, prompt, footer].filter(Boolean).join('\n')); this.restore(); } } module.exports = StringPrompt; /***/ }), /***/ 83546: /***/ ((__unused_webpack_module, exports, __webpack_require__) => { "use strict"; const toString = Object.prototype.toString; const colors = __webpack_require__(53692); let called = false; let fns = []; const complements = { 'yellow': 'blue', 'cyan': 'red', 'green': 'magenta', 'black': 'white', 'blue': 'yellow', 'red': 'cyan', 'magenta': 'green', 'white': 'black' }; exports.longest = (arr, prop) => { return arr.reduce((a, v) => Math.max(a, prop ? v[prop].length : v.length), 0); }; exports.hasColor = str => !!str && colors.hasColor(str); const isObject = exports.isObject = val => { return val !== null && typeof val === 'object' && !Array.isArray(val); }; exports.nativeType = val => { return toString.call(val).slice(8, -1).toLowerCase().replace(/\s/g, ''); }; exports.isAsyncFn = val => { return exports.nativeType(val) === 'asyncfunction'; }; exports.isPrimitive = val => { return val != null && typeof val !== 'object' && typeof val !== 'function'; }; exports.resolve = (context, value, ...rest) => { if (typeof value === 'function') { return value.call(context, ...rest); } return value; }; exports.scrollDown = (choices = []) => [...choices.slice(1), choices[0]]; exports.scrollUp = (choices = []) => [choices.pop(), ...choices]; exports.reorder = (arr = []) => { let res = arr.slice(); res.sort((a, b) => { if (a.index > b.index) return 1; if (a.index < b.index) return -1; return 0; }); return res; }; exports.swap = (arr, index, pos) => { let len = arr.length; let idx = pos === len ? 0 : pos < 0 ? len - 1 : pos; let choice = arr[index]; arr[index] = arr[idx]; arr[idx] = choice; }; exports.width = (stream, fallback = 80) => { let columns = (stream && stream.columns) ? stream.columns : fallback; if (stream && typeof stream.getWindowSize === 'function') { columns = stream.getWindowSize()[0]; } if (process.platform === 'win32') { return columns - 1; } return columns; }; exports.height = (stream, fallback = 20) => { let rows = (stream && stream.rows) ? stream.rows : fallback; if (stream && typeof stream.getWindowSize === 'function') { rows = stream.getWindowSize()[1]; } return rows; }; exports.wordWrap = (str, options = {}) => { if (!str) return str; if (typeof options === 'number') { options = { width: options }; } let { indent = '', newline = ('\n' + indent), width = 80 } = options; let spaces = (newline + indent).match(/[^\S\n]/g) || []; width -= spaces.length; let source = `.{1,${width}}([\\s\\u200B]+|$)|[^\\s\\u200B]+?([\\s\\u200B]+|$)`; let output = str.trim(); let regex = new RegExp(source, 'g'); let lines = output.match(regex) || []; lines = lines.map(line => line.replace(/\n$/, '')); if (options.padEnd) lines = lines.map(line => line.padEnd(width, ' ')); if (options.padStart) lines = lines.map(line => line.padStart(width, ' ')); return indent + lines.join(newline); }; exports.unmute = color => { let name = color.stack.find(n => colors.keys.color.includes(n)); if (name) { return colors[name]; } let bg = color.stack.find(n => n.slice(2) === 'bg'); if (bg) { return colors[name.slice(2)]; } return str => str; }; exports.pascal = str => str ? str[0].toUpperCase() + str.slice(1) : ''; exports.inverse = color => { if (!color || !color.stack) return color; let name = color.stack.find(n => colors.keys.color.includes(n)); if (name) { let col = colors['bg' + exports.pascal(name)]; return col ? col.black : color; } let bg = color.stack.find(n => n.slice(0, 2) === 'bg'); if (bg) { return colors[bg.slice(2).toLowerCase()] || color; } return colors.none; }; exports.complement = color => { if (!color || !color.stack) return color; let name = color.stack.find(n => colors.keys.color.includes(n)); let bg = color.stack.find(n => n.slice(0, 2) === 'bg'); if (name && !bg) { return colors[complements[name] || name]; } if (bg) { let lower = bg.slice(2).toLowerCase(); let comp = complements[lower]; if (!comp) return color; return colors['bg' + exports.pascal(comp)] || color; } return colors.none; }; exports.meridiem = date => { let hours = date.getHours(); let minutes = date.getMinutes(); let ampm = hours >= 12 ? 'pm' : 'am'; hours = hours % 12; let hrs = hours === 0 ? 12 : hours; let min = minutes < 10 ? '0' + minutes : minutes; return hrs + ':' + min + ' ' + ampm; }; /** * Set a value on the given object. * @param {Object} obj * @param {String} prop * @param {any} value */ exports.set = (obj = {}, prop = '', val) => { return prop.split('.').reduce((acc, k, i, arr) => { let value = arr.length - 1 > i ? (acc[k] || {}) : val; if (!exports.isObject(value) && i < arr.length - 1) value = {}; return (acc[k] = value); }, obj); }; /** * Get a value from the given object. * @param {Object} obj * @param {String} prop */ exports.get = (obj = {}, prop = '', fallback) => { let value = obj[prop] == null ? prop.split('.').reduce((acc, k) => acc && acc[k], obj) : obj[prop]; return value == null ? fallback : value; }; exports.mixin = (target, b) => { if (!isObject(target)) return b; if (!isObject(b)) return target; for (let key of Object.keys(b)) { let desc = Object.getOwnPropertyDescriptor(b, key); if (desc.hasOwnProperty('value')) { if (target.hasOwnProperty(key) && isObject(desc.value)) { let existing = Object.getOwnPropertyDescriptor(target, key); if (isObject(existing.value)) { target[key] = exports.merge({}, target[key], b[key]); } else { Reflect.defineProperty(target, key, desc); } } else { Reflect.defineProperty(target, key, desc); } } else { Reflect.defineProperty(target, key, desc); } } return target; }; exports.merge = (...args) => { let target = {}; for (let ele of args) exports.mixin(target, ele); return target; }; exports.mixinEmitter = (obj, emitter) => { let proto = emitter.constructor.prototype; for (let key of Object.keys(proto)) { let val = proto[key]; if (typeof val === 'function') { exports.define(obj, key, val.bind(emitter)); } else { exports.define(obj, key, val); } } }; exports.onExit = callback => { const onExit = (quit, code) => { if (called) return; called = true; fns.forEach(fn => fn()); if (quit === true) { process.exit(128 + code); } }; if (fns.length === 0) { process.once('SIGTERM', onExit.bind(null, true, 15)); process.once('SIGINT', onExit.bind(null, true, 2)); process.once('exit', onExit); } fns.push(callback); }; exports.define = (obj, key, value) => { Reflect.defineProperty(obj, key, { value }); }; exports.defineExport = (obj, key, fn) => { let custom; Reflect.defineProperty(obj, key, { enumerable: true, configurable: true, set(val) { custom = val; }, get() { return custom ? custom() : fn(); } }); }; /***/ }) }; ; //# sourceMappingURL=31.index.js.map