π interactive
interactive::askForConfirmation
Ask the user to press the button to continue.
- $1: prompt as string: the prompt to display
Returns:
- $?:
- 0 if the user pressed enter
- 1 otherwise
interactive::askForConfirmation "Press enter to continue."
interactive::askForConfirmationRaw
Ask the user to press the button to continue.
This raw version does not display the prompt or the answer.
Returns:
- $?:
- 0 if the user pressed enter
- 1 otherwise
interactive::askForConfirmationRaw
interactive::clearKeyPressed
This function reads all the inputs from the user, effectively discarding them.
interactive::clearKeyPressed
interactive::createSpace
This function creates some new lines after the current cursor position. Then it moves back to its original position. This effectively creates a space in the terminal (scroll up if we are at the bottom). It does not create more space than the number of lines in the terminal.
- $1: number of lines as int: the number of lines to create
interactive::createSpace 5
interactive::displayAnswer
Displays an answer to a previous question.
The text is wrapped and put inside a box like so:
βββββββ
β No. ββββ
βββββββ
- $1: answer as string: the answer to display
- $2: max width as int: (optional) the maximum width of the text in the dialog box (defaults to GLOBAL_COLUMNS)
interactive::displayAnswer "My answer."
interactive::displayDialogBox
Displays a dialog box with a speaker and a text.
- $1: speaker as string: the speaker (system or user)
- $2: text as string: the text to display
- $3: max width as int: (optional) the maximum width of the text in the dialog box (defaults to GLOBAL_COLUMNS)
interactive::displayDialogBox "system" "This is a system message."
interactive::displayQuestion
Displays a question to the user.
The text is wrapped and put inside a box like so:
ββββββββββββββββββββββββββββββββββ
ββββ€ Is this an important question? β
ββββββββββββββββββββββββββββββββββ
- $1: prompt as string: the prompt to display
- $2: max width as int: (optional) the maximum width of text in the dialog box (defaults to GLOBAL_COLUMNS)
interactive::displayPrompt "Do you want to continue?"
interactive::getCursorPosition
Get the current cursor position.
Returns:
CURSOR_LINE
: the line numberCURSOR_COLUMN
: the column number
interactive::getCursorPosition
interactive::promptYesNo
Ask the user to yes or no.
The user can switch between the two options with the arrow keys or space.
The user can validate the choice with the enter key.
The user can also validate immediately with the y or n key.
$1: prompt as string: the prompt to display
$2: default as bool: (optional) the default value to select (defaults to true)
Returns:
- $?:
- 0 if the user answered yes
- 1 otherwise
RETURNED_VALUE
: true or false.
if interactive::promptYesNo "Do you want to continue?"; then echo "Yes."; else echo "No."; fi
interactive::promptYesNoRaw
Ask the user to yes or no.
- The user can switch between the two options with the arrow keys or space.
- The user can validate the choice with the enter key.
- The user can also validate immediately with the y or n key.
This raw version does not display the prompt or the answer.
- $1: default as bool: (optional) the default value to select (defaults to true)
Returns:
- $?:
- 0 if the user answered yes
- 1 otherwise
RETURNED_VALUE
: true or false.
interactive::promptYesNoRaw "Do you want to continue?" && local answer="${RETURNED_VALUE}"
interactive::rebindKeymap
Rebinds all special keys to call a callback function interactiveOnKeyBindingPress
.
This allows to use the -e
option with the read command and receive events for special key press.
Key binding is a mess because binding is based on the sequence of characters that gets generated by the terminal when a key is pressed and this is not standard across all terminals. We do our best here to cover most cases but it is by no mean perfect. A good base documentation was https://en.wikipedia.org/wiki/ANSI_escape_code#Terminal_input_sequences.
Users of this function can completely change the bindings afterward by implementing
the interactiveRebindOverride
function.
This function should be called before using interactive::waitForKeyPress.
interactive::rebindKeymap
We do not bother to have a restore function because valet should not be sourced and thus, modifications to the keymap are local to this script.
showkey -a
is a good program to see the sequence of characters sent by the terminal.
interactive::startProgress
Shows a spinner / progress animation with configurable output including a progress bar.
The animation will be displayed until interactive::stopProgress is called or if the max number of frames is reached.
Outputs to stderr. This will run in the background and will not block the main thread. The main thread can continue to output logs while this animation is running.
- $1: output template as string: (optional) the template to display (defaults to VALET_CONFIG_PROGRESS_BAR_TEMPLATE="#spinner #percent β#barβ #message")
- $2: max width as int: (optional) the maximum width of the progress bar (defaults to VALET_CONFIG_PROGRESS_BAR_SIZE=20)
- $3: frame delay as float: (optional) the time in seconds between each frame of the spinner (defaults to VALET_CONFIG_PROGRESS_ANIMATION_DELAY=0.1)
- $4: refresh every x frames as int: (optional) the number of frames of the spinner to wait before refreshing the progress bar (defaults to VALET_CONFIG_PROGRESS_BAR_UPDATE_INTERVAL=3)
- $5: max frames as int: (optional) the maximum number of frames to display (defaults to 9223372036854775807)
- $6: spinner as string: (optional) the spinner to display (each character is a frame) (defaults to VALET_CONFIG_SPINNER_CHARACTERS="β β β Ήβ Έβ Όβ ΄β ¦β §β β ") Examples: - ββββ - ββββ - β£Ύβ£½β£»β’Ώβ‘Ώβ£β£―β£· - β’β’β’β‘β‘β‘β‘ - β‘ββ - ββββ - β β β β β β Έβ °β β °β Έβ β β β
interactive::startProgress "#spinner" "" 0.05 "" "" "β’β’β’β‘β‘β‘β‘ "
wait 4
interactive::stopProgress
interactive::startProgress "#spinner #percent β#barβ #message" 30 0.05 1
IDX=0
while [[ ${IDX} -le 50 ]]; do
interactive::updateProgress $((IDX * 2)) "Doing something ${IDX}/50..."
IDX=$((IDX + 1))
sleep 0.1
done
interactive::stopProgress
Stop the progress bar.
interactive::stopProgress
interactive::sttyInit
Disable the echo of the tty. Will no longer display the characters typed by the user.
interactive::sttyInit
interactive::sttyRestore
Enable the echo of the tty. Will display the characters typed by the user.
- $1: force as bool: (optional) force the restoration of the stty configuration stty state will not be restored if (defaults to false)
interactive::sttyRestore
shellcheck disable=SC2120
interactive::switchBackFromFullScreen
Call this function to switch back from the full screen mode.
- This function will restore the terminal state and show the cursor.
- It will also restore the key echoing.
- If there were error messages during the interactive session, they will be displayed at the end.
interactive::switchBackFromFullScreen
interactive::switchToFullScreen
Call this function to start an interactive session in full screen mode. This function will switch to the alternate screen, hide the cursor and clear the screen. It will also disable echoing when we type something.
You should call interactive::switchBackFromFullScreen at the end of the interactive session.
In the alternate screen, we don’t see the error messages so we capture them somewhere else.
interactive::switchToFullScreen
interactive::testWaitForChar
Wait for the user to send a character to stdin (i.e. wait for a key press) and prints the character that bash reads.
Useful to test the interactive::waitForChar
function and see the char sequence we
get when pressing a key in a given terminal.
See @interactive::waitForChar for more information.
interactive::testWaitForChar
interactive::testWaitForKeyPress
Wait for the user to press a key and prints it to the screen.
This function is used to test the interactive::waitForKeyPress
function.
See @interactive::waitForKeyPress for more information.
interactive::testWaitForKeyPress
interactive::updateProgress
Update the progress bar with a new percentage and message.
The animation can be started with interactive::startProgress for more options. The animation will stop if the updated percentage is 100.
- $1: percent as int: the percentage of the progress bar (0 to 100)
- $2: message as string: (optional) the message to display
interactive::updateProgress 50 "Doing something..."
interactive::waitForChar
Wait for a user input (single char). You can pass additional parameters to the read command (e.g. to wait for a set amount of time).
It uses the read builtin command. This will not detect all key combinations. The output will depend on the terminal used and the character sequences it sends on each key press.
For more advanced use cases, you can use interactive::waitForKeyPress. This simple implementation does not rely on GNU readline and does not require stty to be initialized.
Some special keys are translated into more readable strings: UP, DOWN, RIGHT, LEFT, BACKSPACE, DEL, PAGE_UP, PAGE_DOWN, HOME, END, ESC, F1-F12, ALT+…
- $@: read parameters as any: additional parameters to pass to the read command
Returns:
- $?:
- 0 if a char was retrieved
- 1 otherwise
LAST_KEY_PRESSED
: the last char (key) retrieved.
interactive::waitForChar
interactive::waitForChar -t 0.1
https://en.wikipedia.org/wiki/ANSI_escape_code#Terminal_input_sequences
interactive::waitForKeyPress
Wait for a key press (single key). You can pass additional parameters to the read command (e.g. to wait for a set amount of time).
It uses the read builtin command with the option -e
to use readline behind the scene.
This means we can detect more key combinations but all keys needs to be bound first…
Special keys (CTRL+, ALT+, F1-F12, arrows, etc.) are intercepted using binding.
You must call interactive::rebindKeymap
and interactive::sttyInit
before using this function.
You must also redefine the function interactiveOnKeyBindingPress
to react to a bound key press.
See @interactive::testWaitForKeyPress for an implementation example.
- $@: read parameters as any: additional parameters to pass to the read command
Returns:
- $?:
- 0 if a key was pressed
- 1 otherwise
LAST_KEY_PRESSED
: the key pressed.
interactive::waitForKeyPress
interactive::waitForKeyPress -t 0.1
Due to a bug in bash, if the cursor is at the end of the screen, it will make the screen scroll even when nothing is read… Make sure to not position the cursor at the end of the screen.
Documentation generated for the version 0.27.285 (2024-12-05).