Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

prompt-base

Package Overview
Dependencies
Maintainers
2
Versions
41
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

prompt-base

Base prompt module used for creating custom prompt types for Enquirer.

  • 0.6.0
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
50K
increased by23.99%
Maintainers
2
Weekly downloads
 
Created
Source

prompt-base NPM version NPM monthly downloads NPM total downloads Linux Build Status Windows Build Status

Base prompt module used for creating custom prompt types for Enquirer.

Install

Install with npm:

$ npm install --save prompt-base

Usage

See the examples folder for more detailed usage examples.

var Prompt = require('prompt-base');
var prompt = new Prompt({
  name: 'color',
  message: 'What is your favorite color?'
});

prompt.run()
  .then(function(answer) {
    console.log(answer);
  })

API

Prompt

Create a new Prompt with the given question object, answers and optional instance of readline-ui.

Params

  • question {Object}: Plain object or instance of prompt-question.
  • answers {Object}: Optionally pass an answers object from a prompt manager (like enquirer).
  • ui {Object}: Optionally pass an instance of readline-ui. If not passed, an instance is created for you.

Example

var prompt = new Prompt({
  name: 'color',
  message: 'What is your favorite color?'
});

prompt.ask(function(answer) {
  console.log(answer);
  //=> 'blue'
});

.run

Initialize a prompt and resolve answers. If question.when returns false, the prompt will be skipped.

Params

  • answers {Object}
  • returns {Promise}

.ask

Default ask method. This mayb eb overridden in custom prompts.

.render

Render the current prompt input. This can be replaced by custom prompts.

Example

prompt.ui.on('keypress', prompt.render.bind(prompt));

.move

Move the cursor in the specific direction when the given event is emitted.

Params

  • direction {String}
  • event {Object}

.onKeypress

Default keypress event handler. This may be overridden in custom prompts.

Params

  • event {Object}

.onSubmit

When the answer is submitted (user presses enter key), re-render and pass answer to callback. This may be replaced by custom prompts.

Params

  • input {Object}

.onTabKey

Default tab event handler. This may be overridden in custom prompts.

Params

  • event {Object}

.onError

Default error event handler. This may be overridden in custom prompts.

Params

  • event {Object}

.format

Returns a formatted prompt message.

  • returns {String}

.choices

Getter for getting the choices array from the question.

  • returns {Object}: Choices object

.message

Getter that returns question.message after passing it to format.

  • returns {String}: A formatted prompt message.

.prefix

Getter that returns the prefix to use before question.message. The default value is a green ?.

  • returns {String}: The formatted prefix.

Example

prompt.prefix = '!';

.Separator

Create a new Separator object. See choices-separator for more details.

Params

  • separator {String}: Optionally pass a string to use as the separator.
  • returns {Object}: Returns a separator object.

Example

new Prompt.Separator('---');

Examples

Instantiate

The main purpose of this library is to be inherited by other libraries to create custom prompt types. However, the main export is a function that can be instantiated to run basic "input" prompts, if you want to see how everything works, run examples, tests, etc.

var Prompt = require('prompt-base');
var prompt = new Prompt({
  name: 'first',
  message: 'What is your name?'
});

// callback
prompt.ask(function(answer) {
  console.log(answer);
  //=> 'Jon'
});

// promise
prompt.run()
  .then(function(answers) {
    console.log(answers);
    //=> {first: 'Jon'}
  });

Inherit

var Prompt = require('prompt-base');

function CustomPrompt(/*question, answers, rl*/) {
  Prompt.apply(this, arguments);
}

util.inherits(CustomPrompt, Prompt);

In the wild

The following custom prompts were created using this library:

About

Contributing

Pull requests and stars are always welcome. For bugs and feature requests, please create an issue.

Please read the contributing guide for advice on opening issues, pull requests, and coding standards.

Contributors

CommitsContributor
43jonschlinkert
5doowb

Building docs

(This project's readme.md is generated by verb, please don't edit the readme directly. Any changes to the readme must be made in the .verb.md readme template.)

To generate the readme, run the following command:

$ npm install -g verbose/verb#dev verb-generate-readme && verb

Running tests

Running and reviewing unit tests is a great way to get familiarized with a library and its API. You can install dependencies and run tests with the following command:

$ npm install && npm test

Author

Jon Schlinkert

License

Copyright © 2017, Jon Schlinkert. Released under the MIT License.


This file was generated by verb-generate-readme, v0.4.3, on March 10, 2017.

Keywords

FAQs

Package last updated on 10 Mar 2017

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc