aboutsummaryrefslogtreecommitdiff
path: root/sandbox/testAppNevena/Front/node_modules/inquirer/lib/ui
diff options
context:
space:
mode:
Diffstat (limited to 'sandbox/testAppNevena/Front/node_modules/inquirer/lib/ui')
-rw-r--r--sandbox/testAppNevena/Front/node_modules/inquirer/lib/ui/baseUI.js99
-rw-r--r--sandbox/testAppNevena/Front/node_modules/inquirer/lib/ui/bottom-bar.js102
-rw-r--r--sandbox/testAppNevena/Front/node_modules/inquirer/lib/ui/prompt.js150
3 files changed, 0 insertions, 351 deletions
diff --git a/sandbox/testAppNevena/Front/node_modules/inquirer/lib/ui/baseUI.js b/sandbox/testAppNevena/Front/node_modules/inquirer/lib/ui/baseUI.js
deleted file mode 100644
index 547e5658..00000000
--- a/sandbox/testAppNevena/Front/node_modules/inquirer/lib/ui/baseUI.js
+++ /dev/null
@@ -1,99 +0,0 @@
-'use strict';
-const _ = {
- extend: require('lodash/extend'),
- omit: require('lodash/omit'),
-};
-const MuteStream = require('mute-stream');
-const readline = require('readline');
-
-/**
- * Base interface class other can inherits from
- */
-
-class UI {
- constructor(opt) {
- // Instantiate the Readline interface
- // @Note: Don't reassign if already present (allow test to override the Stream)
- if (!this.rl) {
- this.rl = readline.createInterface(setupReadlineOptions(opt));
- }
-
- this.rl.resume();
-
- this.onForceClose = this.onForceClose.bind(this);
-
- // Make sure new prompt start on a newline when closing
- process.on('exit', this.onForceClose);
-
- // Terminate process on SIGINT (which will call process.on('exit') in return)
- this.rl.on('SIGINT', this.onForceClose);
- }
-
- /**
- * Handle the ^C exit
- * @return {null}
- */
-
- onForceClose() {
- this.close();
- process.kill(process.pid, 'SIGINT');
- console.log('');
- }
-
- /**
- * Close the interface and cleanup listeners
- */
-
- close() {
- // Remove events listeners
- this.rl.removeListener('SIGINT', this.onForceClose);
- process.removeListener('exit', this.onForceClose);
-
- this.rl.output.unmute();
-
- if (this.activePrompt && typeof this.activePrompt.close === 'function') {
- this.activePrompt.close();
- }
-
- // Close the readline
- this.rl.output.end();
- this.rl.pause();
- this.rl.close();
- }
-}
-
-function setupReadlineOptions(opt) {
- opt = opt || {};
- // Inquirer 8.x:
- // opt.skipTTYChecks = opt.skipTTYChecks === undefined ? opt.input !== undefined : opt.skipTTYChecks;
- opt.skipTTYChecks = opt.skipTTYChecks === undefined ? true : opt.skipTTYChecks;
-
- // Default `input` to stdin
- const input = opt.input || process.stdin;
-
- // Check if prompt is being called in TTY environment
- // If it isn't return a failed promise
- if (!opt.skipTTYChecks && !input.isTTY) {
- const nonTtyError = new Error(
- 'Prompts can not be meaningfully rendered in non-TTY environments'
- );
- nonTtyError.isTtyError = true;
- throw nonTtyError;
- }
-
- // Add mute capabilities to the output
- const ms = new MuteStream();
- ms.pipe(opt.output || process.stdout);
- const output = ms;
-
- return _.extend(
- {
- terminal: true,
- input,
- output,
- },
- _.omit(opt, ['input', 'output'])
- );
-}
-
-module.exports = UI;
diff --git a/sandbox/testAppNevena/Front/node_modules/inquirer/lib/ui/bottom-bar.js b/sandbox/testAppNevena/Front/node_modules/inquirer/lib/ui/bottom-bar.js
deleted file mode 100644
index 9235273e..00000000
--- a/sandbox/testAppNevena/Front/node_modules/inquirer/lib/ui/bottom-bar.js
+++ /dev/null
@@ -1,102 +0,0 @@
-'use strict';
-/**
- * Sticky bottom bar user interface
- */
-
-const through = require('through');
-const Base = require('./baseUI');
-const rlUtils = require('../utils/readline');
-const _ = {
- last: require('lodash/last'),
-};
-
-class BottomBar extends Base {
- constructor(opt) {
- opt = opt || {};
-
- super(opt);
-
- this.log = through(this.writeLog.bind(this));
- this.bottomBar = opt.bottomBar || '';
- this.render();
- }
-
- /**
- * Render the prompt to screen
- * @return {BottomBar} self
- */
-
- render() {
- this.write(this.bottomBar);
- return this;
- }
-
- clean() {
- rlUtils.clearLine(this.rl, this.bottomBar.split('\n').length);
- return this;
- }
-
- /**
- * Update the bottom bar content and rerender
- * @param {String} bottomBar Bottom bar content
- * @return {BottomBar} self
- */
-
- updateBottomBar(bottomBar) {
- rlUtils.clearLine(this.rl, 1);
- this.rl.output.unmute();
- this.clean();
- this.bottomBar = bottomBar;
- this.render();
- this.rl.output.mute();
- return this;
- }
-
- /**
- * Write out log data
- * @param {String} data - The log data to be output
- * @return {BottomBar} self
- */
-
- writeLog(data) {
- this.rl.output.unmute();
- this.clean();
- this.rl.output.write(this.enforceLF(data.toString()));
- this.render();
- this.rl.output.mute();
- return this;
- }
-
- /**
- * Make sure line end on a line feed
- * @param {String} str Input string
- * @return {String} The input string with a final line feed
- */
-
- enforceLF(str) {
- return str.match(/[\r\n]$/) ? str : str + '\n';
- }
-
- /**
- * Helper for writing message in Prompt
- * @param {BottomBar} prompt - The Prompt object that extends tty
- * @param {String} message - The message to be output
- */
- write(message) {
- const msgLines = message.split(/\n/);
- this.height = msgLines.length;
-
- // Write message to screen and setPrompt to control backspace
- this.rl.setPrompt(_.last(msgLines));
-
- if (this.rl.output.rows === 0 && this.rl.output.columns === 0) {
- /* When it's a tty through serial port there's no terminal info and the render will malfunction,
- so we need enforce the cursor to locate to the leftmost position for rendering. */
- rlUtils.left(this.rl, message.length + this.rl.line.length);
- }
-
- this.rl.output.write(message);
- }
-}
-
-module.exports = BottomBar;
diff --git a/sandbox/testAppNevena/Front/node_modules/inquirer/lib/ui/prompt.js b/sandbox/testAppNevena/Front/node_modules/inquirer/lib/ui/prompt.js
deleted file mode 100644
index d9383879..00000000
--- a/sandbox/testAppNevena/Front/node_modules/inquirer/lib/ui/prompt.js
+++ /dev/null
@@ -1,150 +0,0 @@
-'use strict';
-const _ = {
- isPlainObject: require('lodash/isPlainObject'),
- clone: require('lodash/clone'),
- isArray: require('lodash/isArray'),
- get: require('lodash/get'),
- set: require('lodash/set'),
- isFunction: require('lodash/isFunction'),
-};
-const { defer, empty, from, of } = require('rxjs');
-const { concatMap, filter, publish, reduce } = require('rxjs/operators');
-const runAsync = require('run-async');
-const utils = require('../utils/utils');
-const Base = require('./baseUI');
-
-/**
- * Base interface class other can inherits from
- */
-
-class PromptUI extends Base {
- constructor(prompts, opt) {
- super(opt);
- this.prompts = prompts;
- }
-
- run(questions, answers) {
- // Keep global reference to the answers
- if (_.isPlainObject(answers)) {
- this.answers = _.clone(answers);
- } else {
- this.answers = {};
- }
-
- // Make sure questions is an array.
- if (_.isPlainObject(questions)) {
- // It's either an object of questions or a single question
- questions = Object.values(questions).every(
- (v) => _.isPlainObject(v) && v.name === undefined
- )
- ? Object.entries(questions).map(([name, question]) => ({ name, ...question }))
- : [questions];
- }
-
- // Create an observable, unless we received one as parameter.
- // Note: As this is a public interface, we cannot do an instanceof check as we won't
- // be using the exact same object in memory.
- const obs = _.isArray(questions) ? from(questions) : questions;
-
- this.process = obs.pipe(
- concatMap(this.processQuestion.bind(this)),
- publish() // Creates a hot Observable. It prevents duplicating prompts.
- );
-
- this.process.connect();
-
- return this.process
- .pipe(
- reduce((answers, answer) => {
- _.set(answers, answer.name, answer.answer);
- return answers;
- }, this.answers)
- )
- .toPromise(Promise)
- .then(this.onCompletion.bind(this), this.onError.bind(this));
- }
-
- /**
- * Once all prompt are over
- */
-
- onCompletion() {
- this.close();
-
- return this.answers;
- }
-
- onError(error) {
- this.close();
- return Promise.reject(error);
- }
-
- processQuestion(question) {
- question = _.clone(question);
- return defer(() => {
- const obs = of(question);
-
- return obs.pipe(
- concatMap(this.setDefaultType.bind(this)),
- concatMap(this.filterIfRunnable.bind(this)),
- concatMap(() =>
- utils.fetchAsyncQuestionProperty(question, 'message', this.answers)
- ),
- concatMap(() =>
- utils.fetchAsyncQuestionProperty(question, 'default', this.answers)
- ),
- concatMap(() =>
- utils.fetchAsyncQuestionProperty(question, 'choices', this.answers)
- ),
- concatMap(this.fetchAnswer.bind(this))
- );
- });
- }
-
- fetchAnswer(question) {
- const Prompt = this.prompts[question.type];
- this.activePrompt = new Prompt(question, this.rl, this.answers);
- return defer(() =>
- from(this.activePrompt.run().then((answer) => ({ name: question.name, answer })))
- );
- }
-
- setDefaultType(question) {
- // Default type to input
- if (!this.prompts[question.type]) {
- question.type = 'input';
- }
-
- return defer(() => of(question));
- }
-
- filterIfRunnable(question) {
- if (
- question.askAnswered !== true &&
- _.get(this.answers, question.name) !== undefined
- ) {
- return empty();
- }
-
- if (question.when === false) {
- return empty();
- }
-
- if (!_.isFunction(question.when)) {
- return of(question);
- }
-
- const { answers } = this;
- return defer(() =>
- from(
- runAsync(question.when)(answers).then((shouldRun) => {
- if (shouldRun) {
- return question;
- }
- })
- ).pipe(filter((val) => val != null))
- );
- }
-}
-
-module.exports = PromptUI;