Class: TTY::Prompt
- Inherits:
-
Object
- Object
- TTY::Prompt
- Extended by:
- Forwardable
- Defined in:
- lib/tty/prompt.rb,
lib/tty/prompt/list.rb,
lib/tty/prompt/test.rb,
lib/tty/prompt/const.rb,
lib/tty/prompt/timer.rb,
lib/tty/prompt/choice.rb,
lib/tty/prompt/errors.rb,
lib/tty/prompt/result.rb,
lib/tty/prompt/slider.rb,
lib/tty/prompt/choices.rb,
lib/tty/prompt/symbols.rb,
lib/tty/prompt/version.rb,
lib/tty/prompt/distance.rb,
lib/tty/prompt/expander.rb,
lib/tty/prompt/keypress.rb,
lib/tty/prompt/question.rb,
lib/tty/prompt/enum_list.rb,
lib/tty/prompt/evaluator.rb,
lib/tty/prompt/multiline.rb,
lib/tty/prompt/paginator.rb,
lib/tty/prompt/statement.rb,
lib/tty/prompt/converters.rb,
lib/tty/prompt/multi_list.rb,
lib/tty/prompt/suggestion.rb,
lib/tty/prompt/converter_dsl.rb,
lib/tty/prompt/mask_question.rb,
lib/tty/prompt/block_paginator.rb,
lib/tty/prompt/question/checks.rb,
lib/tty/prompt/confirm_question.rb,
lib/tty/prompt/selected_choices.rb,
lib/tty/prompt/answers_collector.rb,
lib/tty/prompt/question/modifier.rb,
lib/tty/prompt/converter_registry.rb,
lib/tty/prompt/question/validation.rb
Overview
A class responsible for terminal prompt interactions.
Direct Known Subclasses
Defined Under Namespace
Modules: Const, ConverterDSL, Converters, StringIOExtensions, Symbols Classes: AnswersCollector, BlockPaginator, Choice, Choices, ConfirmQuestion, ConverterRegistry, Distance, EnumList, Evaluator, Expander, Keypress, List, MaskQuestion, MultiList, Multiline, Paginator, Question, Result, SelectedChoices, Slider, Statement, Suggestion, Test, Timer
Constant Summary collapse
- Error =
Class.new(StandardError)
- ConfigurationError =
Raised when wrong parameter is used to configure prompt
Class.new(Error)
- ConversionError =
Raised when type conversion cannot be performed
Class.new(Error)
- ValidationCoercion =
Raised when the passed in validation argument is of wrong type
Class.new(Error)
- ArgumentRequired =
Raised when the required argument is not supplied
Class.new(Error)
- ArgumentValidation =
Raised when the argument validation fails
Class.new(Error)
- InvalidArgument =
Raised when the argument is not expected
Class.new(Error)
- ConversionAlreadyDefined =
Raised when overriding already defined conversion
Class.new(Error)
- UnsupportedConversion =
Raised when conversion type isn’t registered
Class.new(Error)
- VERSION =
"0.23.1"
Instance Attribute Summary collapse
-
#active_color ⇒ Object
readonly
private
Theme colors.
-
#cursor ⇒ Object
readonly
Returns the value of attribute cursor.
-
#enabled_color ⇒ Object
readonly
private
Theme colors.
-
#error_color ⇒ Object
readonly
private
Theme colors.
-
#help_color ⇒ Object
readonly
private
Theme colors.
- #input ⇒ Object readonly private
- #output ⇒ Object readonly private
-
#prefix ⇒ String
readonly
private
Prompt prefix.
-
#quiet ⇒ Object
readonly
private
Quiet mode.
-
#reader ⇒ Object
readonly
Returns the value of attribute reader.
-
#symbols ⇒ Hash
readonly
private
The collection of display symbols.
Class Method Summary collapse
Instance Method Summary collapse
-
#ask(message = "", **options) {|question| ... } ⇒ TTY::Prompt::Question
Ask a question.
-
#collect(**options, &block) ⇒ Hash
Gathers more than one aswer.
-
#debug(*messages) ⇒ Object
Print debug information in terminal top right corner.
-
#decorate(string, *colors) ⇒ Object
Decorate a string with colors.
-
#enum_select(question, *args, &block) ⇒ String
Ask a question with indexed list.
-
#error(*args, **options) ⇒ Array
Print statement(s) out in red color.
-
#expand(message, *args, &block) ⇒ Object
Expand available options.
-
#initialize(input: $stdin, output: $stdout, env: ENV, symbols: {}, prefix: "", interrupt: :error, track_history: true, quiet: false, enable_color: nil, active_color: :green, help_color: :bright_black, error_color: :red) ⇒ Prompt
constructor
Initialize a Prompt.
-
#inspect ⇒ String
Inspect this instance public attributes.
-
#invoke_question(object, message, **options, &block) ⇒ String
Invoke a question type of prompt.
-
#invoke_select(object, question, *args, &block) ⇒ String
Invoke a list type of prompt.
-
#keypress(message = "", **options, &block) ⇒ Object
Ask a question with a keypress answer.
-
#mask(message = "", **options, &block) ⇒ TTY::Prompt::MaskQuestion
Ask masked question.
-
#multi_select(question, *args, &block) ⇒ String
Ask a question with multiple attributes activated.
-
#multiline(message = "", **options, &block) ⇒ Array[String]
Ask a question with a multiline answer.
-
#no?(message, **options, &block) ⇒ Boolean
A shortcut method to ask the user negative question and return true for “no” reply.
-
#ok(*args, **options) ⇒ Array
Print statement(s) out in red green.
-
#say(message = "", **options) ⇒ String
Print statement out.
-
#select(question, *args, &block) ⇒ Object
Ask a question with a list of options.
-
#slider(question, choices = nil, **options, &block) ⇒ String
Ask a question with a range slider.
-
#stderr ⇒ Object
private
Return standard error.
-
#stdin ⇒ Object
private
Return standard in.
-
#stdout ⇒ Object
private
Return standard out.
-
#suggest(message, possibilities, **options) ⇒ String
Takes the string provided by the user and compare it with other possible matches to suggest an unambigous string.
-
#tty? ⇒ Boolean
Check if outputing to terminal.
-
#warn(*args, **options) ⇒ Array
Print statement(s) out in yellow color.
-
#yes?(message, **options, &block) ⇒ Boolean
A shortcut method to ask the user positive question and return true for “yes” reply, false for “no”.
Constructor Details
#initialize(input: $stdin, output: $stdout, env: ENV, symbols: {}, prefix: "", interrupt: :error, track_history: true, quiet: false, enable_color: nil, active_color: :green, help_color: :bright_black, error_color: :red) ⇒ Prompt
Initialize a Prompt
120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 |
# File 'lib/tty/prompt.rb', line 120 def initialize(input: $stdin, output: $stdout, env: ENV, symbols: {}, prefix: "", interrupt: :error, track_history: true, quiet: false, enable_color: nil, active_color: :green, help_color: :bright_black, error_color: :red) @input = input @output = output @env = env @prefix = prefix @enabled_color = enable_color @active_color = active_color @help_color = help_color @error_color = error_color @interrupt = interrupt @track_history = track_history @symbols = Symbols.symbols.merge(symbols) @quiet = quiet @cursor = TTY::Cursor @pastel = enabled_color.nil? ? Pastel.new : Pastel.new(enabled: enabled_color) @reader = TTY::Reader.new( input: input, output: output, interrupt: interrupt, track_history: track_history, env: env ) end |
Instance Attribute Details
#active_color ⇒ Object (readonly)
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
Theme colors
55 56 57 |
# File 'lib/tty/prompt.rb', line 55 def active_color @active_color end |
#cursor ⇒ Object (readonly)
Returns the value of attribute cursor.
40 41 42 |
# File 'lib/tty/prompt.rb', line 40 def cursor @cursor end |
#enabled_color ⇒ Object (readonly)
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
Theme colors
55 56 57 |
# File 'lib/tty/prompt.rb', line 55 def enabled_color @enabled_color end |
#error_color ⇒ Object (readonly)
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
Theme colors
55 56 57 |
# File 'lib/tty/prompt.rb', line 55 def error_color @error_color end |
#help_color ⇒ Object (readonly)
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
Theme colors
55 56 57 |
# File 'lib/tty/prompt.rb', line 55 def help_color @help_color end |
#input ⇒ Object (readonly)
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
33 34 35 |
# File 'lib/tty/prompt.rb', line 33 def input @input end |
#output ⇒ Object (readonly)
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
36 37 38 |
# File 'lib/tty/prompt.rb', line 36 def output @output end |
#prefix ⇒ String (readonly)
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
Prompt prefix
50 51 52 |
# File 'lib/tty/prompt.rb', line 50 def prefix @prefix end |
#quiet ⇒ Object (readonly)
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
Quiet mode
60 61 62 |
# File 'lib/tty/prompt.rb', line 60 def quiet @quiet end |
#reader ⇒ Object (readonly)
Returns the value of attribute reader.
38 39 40 |
# File 'lib/tty/prompt.rb', line 38 def reader @reader end |
#symbols ⇒ Hash (readonly)
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
The collection of display symbols
70 71 72 |
# File 'lib/tty/prompt.rb', line 70 def symbols @symbols end |
Class Method Details
.messages ⇒ Object
83 84 85 86 87 88 89 90 |
# File 'lib/tty/prompt.rb', line 83 def self. { range?: "Value %{value} must be within the range %{in}", valid?: "Your answer is invalid (must match %{valid})", required?: "Value must be provided", convert?: "Cannot convert `%{value}` to '%{type}' type" } end |
Instance Method Details
#ask(message = "", **options) {|question| ... } ⇒ TTY::Prompt::Question
Ask a question.
201 202 203 |
# File 'lib/tty/prompt.rb', line 201 def ask( = "", **, &block) invoke_question(Question, , **, &block) end |
#collect(**options, &block) ⇒ Hash
Gathers more than one aswer
534 535 536 537 |
# File 'lib/tty/prompt.rb', line 534 def collect(**, &block) collector = AnswersCollector.new(self, **) collector.call(&block) end |
#debug(*messages) ⇒ Object
Print debug information in terminal top right corner
484 485 486 487 488 489 490 491 492 493 494 |
# File 'lib/tty/prompt.rb', line 484 def debug(*) longest = .max_by(&:length).size width = TTY::Screen.width - longest print cursor.save .reverse_each do |msg| print cursor.column(width) + cursor.up + cursor.clear_line_after print msg end ensure print cursor.restore end |
#decorate(string, *colors) ⇒ Object
Decorate a string with colors
156 157 158 159 160 161 162 163 164 165 166 167 |
# File 'lib/tty/prompt.rb', line 156 def decorate(string, *colors) if Utils.blank?(string) || @enabled_color == false || colors.empty? return string end coloring = colors.first if coloring.respond_to?(:call) coloring.call(string) else @pastel.decorate(string, *colors) end end |
#enum_select(question, *args, &block) ⇒ String
Ask a question with indexed list
325 326 327 |
# File 'lib/tty/prompt.rb', line 325 def enum_select(question, *args, &block) invoke_select(EnumList, question, *args, &block) end |
#error(*args, **options) ⇒ Array
Print statement(s) out in red color.
469 470 471 472 |
# File 'lib/tty/prompt.rb', line 469 def error(*args, **) opts = { color: :red }.merge() args.each { || say(, **opts) } end |
#expand(message, *args, &block) ⇒ Object
Expand available options
382 383 384 |
# File 'lib/tty/prompt.rb', line 382 def (, *args, &block) invoke_select(Expander, , *args, &block) end |
#inspect ⇒ String
Inspect this instance public attributes
574 575 576 577 578 579 580 581 582 583 584 585 586 587 |
# File 'lib/tty/prompt.rb', line 574 def inspect attributes = [ :prefix, :quiet, :enabled_color, :active_color, :error_color, :help_color, :input, :output, ] name = self.class.name "#<#{name}#{attributes.map { |attr| " #{attr}=#{send(attr).inspect}" }.join}>" end |
#invoke_question(object, message, **options, &block) ⇒ String
Invoke a question type of prompt
178 179 180 181 182 |
# File 'lib/tty/prompt.rb', line 178 def invoke_question(object, , **, &block) [:messages] = self.class. question = object.new(self, **) question.(, &block) end |
#invoke_select(object, question, *args, &block) ⇒ String
Invoke a list type of prompt
236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 |
# File 'lib/tty/prompt.rb', line 236 def invoke_select(object, question, *args, &block) = Utils.(args) choices = if args.empty? && !block possible = .dup = {} possible elsif args.size == 1 && args[0].is_a?(Hash) Utils.(args) else args.flatten end list = object.new(self, **) list.(question, choices, &block) end |
#keypress(message = "", **options, &block) ⇒ Object
Ask a question with a keypress answer
210 211 212 |
# File 'lib/tty/prompt.rb', line 210 def keypress( = "", **, &block) invoke_question(Keypress, , **, &block) end |
#mask(message = "", **options, &block) ⇒ TTY::Prompt::MaskQuestion
Ask masked question
261 262 263 |
# File 'lib/tty/prompt.rb', line 261 def mask( = "", **, &block) invoke_question(MaskQuestion, , **, &block) end |
#multi_select(question, *args, &block) ⇒ String
Ask a question with multiple attributes activated
305 306 307 |
# File 'lib/tty/prompt.rb', line 305 def multi_select(question, *args, &block) invoke_select(MultiList, question, *args, &block) end |
#multiline(message = "", **options, &block) ⇒ Array[String]
Ask a question with a multiline answer
222 223 224 |
# File 'lib/tty/prompt.rb', line 222 def multiline( = "", **, &block) invoke_question(Multiline, , **, &block) end |
#no?(message, **options, &block) ⇒ Boolean
A shortcut method to ask the user negative question and return true for “no” reply.
357 358 359 360 361 |
# File 'lib/tty/prompt.rb', line 357 def no?(, **, &block) opts = { default: false }.merge() question = ConfirmQuestion.new(self, **opts) !question.call(, &block) end |
#ok(*args, **options) ⇒ Array
Print statement(s) out in red green.
437 438 439 440 |
# File 'lib/tty/prompt.rb', line 437 def ok(*args, **) opts = { color: :green }.merge() args.each { || say(, **opts) } end |
#say(message = "", **options) ⇒ String
Print statement out. If the supplied message ends with a space or tab character, a new line will not be appended.
418 419 420 421 422 423 424 |
# File 'lib/tty/prompt.rb', line 418 def say( = "", **) = .to_s return if .empty? statement = Statement.new(self, **) statement.call() end |
#select(question, *args, &block) ⇒ Object
Ask a question with a list of options
285 286 287 |
# File 'lib/tty/prompt.rb', line 285 def select(question, *args, &block) invoke_select(List, question, *args, &block) end |
#slider(question, choices = nil, **options, &block) ⇒ String
Ask a question with a range slider
402 403 404 405 |
# File 'lib/tty/prompt.rb', line 402 def (question, choices = nil, **, &block) = Slider.new(self, **) .call(question, choices, &block) end |
#stderr ⇒ Object
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
Return standard error
565 566 567 |
# File 'lib/tty/prompt.rb', line 565 def stderr $stderr end |
#stdin ⇒ Object
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
Return standard in
551 552 553 |
# File 'lib/tty/prompt.rb', line 551 def stdin $stdin end |
#stdout ⇒ Object
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
Return standard out
558 559 560 |
# File 'lib/tty/prompt.rb', line 558 def stdout $stdout end |
#suggest(message, possibilities, **options) ⇒ String
Takes the string provided by the user and compare it with other possible matches to suggest an unambigous string
518 519 520 521 |
# File 'lib/tty/prompt.rb', line 518 def suggest(, possibilities, **) suggestion = Suggestion.new(**) say(suggestion.suggest(, possibilities)) end |
#tty? ⇒ Boolean
Check if outputing to terminal
544 545 546 |
# File 'lib/tty/prompt.rb', line 544 def tty? stdout.tty? end |
#warn(*args, **options) ⇒ Array
Print statement(s) out in yellow color.
453 454 455 456 |
# File 'lib/tty/prompt.rb', line 453 def warn(*args, **) opts = { color: :yellow }.merge() args.each { || say(, **opts) } end |
#yes?(message, **options, &block) ⇒ Boolean
A shortcut method to ask the user positive question and return true for “yes” reply, false for “no”.
340 341 342 343 344 |
# File 'lib/tty/prompt.rb', line 340 def yes?(, **, &block) opts = { default: true }.merge() question = ConfirmQuestion.new(self, **opts) question.call(, &block) end |