mirror of
https://github.com/strongdm/comply
synced 2024-11-09 01:14:53 +00:00
107 lines
2.6 KiB
Markdown
107 lines
2.6 KiB
Markdown
# promptui
|
|
|
|
Interactive prompt for command-line applications.
|
|
|
|
We built Promptui because we wanted to make it easy and fun to explore cloud services with [manifold cli](https://github.com/manifoldco/manifold-cli).
|
|
|
|
[Code of Conduct](./CODE_OF_CONDUCT.md) |
|
|
[Contribution Guidelines](./.github/CONTRIBUTING.md)
|
|
|
|
[![GitHub release](https://img.shields.io/github/tag/manifoldco/promptui.svg?label=latest)](https://github.com/manifoldco/promptui/releases)
|
|
[![GoDoc](https://img.shields.io/badge/godoc-reference-blue.svg)](https://godoc.org/github.com/manifoldco/promptui)
|
|
[![Travis](https://img.shields.io/travis/manifoldco/promptui/master.svg)](https://travis-ci.org/manifoldco/promptui)
|
|
[![Go Report Card](https://goreportcard.com/badge/github.com/manifoldco/promptui)](https://goreportcard.com/report/github.com/manifoldco/promptui)
|
|
[![License](https://img.shields.io/badge/license-BSD-blue.svg)](./LICENSE.md)
|
|
|
|
## Overview
|
|
|
|
![promptui](https://media.giphy.com/media/xUNda0Ngb5qsogLsBi/giphy.gif)
|
|
|
|
Promptui is a library providing a simple interface to create command-line
|
|
prompts for go. It can be easily integrated into
|
|
[spf13/cobra](https://github.com/spf13/cobra),
|
|
[urfave/cli](https://github.com/urfave/cli) or any cli go application.
|
|
|
|
Promptui has two main input modes:
|
|
|
|
- `Prompt` provides a single line for user input. Prompt supports
|
|
optional live validation, confirmation and masking the input.
|
|
|
|
- `Select` provides a list of options to choose from. Select supports
|
|
pagination, search, detailed view and custom templates.
|
|
|
|
For a full list of options check [GoDoc](https://godoc.org/github.com/manifoldco/promptui).
|
|
|
|
## Basic Usage
|
|
|
|
### Prompt
|
|
|
|
```go
|
|
package main
|
|
|
|
import (
|
|
"errors"
|
|
"fmt"
|
|
"strconv"
|
|
|
|
"github.com/manifoldco/promptui"
|
|
)
|
|
|
|
func main() {
|
|
validate := func(input string) error {
|
|
_, err := strconv.ParseFloat(input, 64)
|
|
if err != nil {
|
|
return errors.New("Invalid number")
|
|
}
|
|
return nil
|
|
}
|
|
|
|
prompt := promptui.Prompt{
|
|
Label: "Number",
|
|
Validate: validate,
|
|
}
|
|
|
|
result, err := prompt.Run()
|
|
|
|
if err != nil {
|
|
fmt.Printf("Prompt failed %v\n", err)
|
|
return
|
|
}
|
|
|
|
fmt.Printf("You choose %q\n", result)
|
|
}
|
|
```
|
|
|
|
### Select
|
|
|
|
```go
|
|
package main
|
|
|
|
import (
|
|
"fmt"
|
|
|
|
"github.com/manifoldco/promptui"
|
|
)
|
|
|
|
func main() {
|
|
prompt := promptui.Select{
|
|
Label: "Select Day",
|
|
Items: []string{"Monday", "Tuesday", "Wednesday", "Thursday", "Friday",
|
|
"Saturday", "Sunday"},
|
|
}
|
|
|
|
_, result, err := prompt.Run()
|
|
|
|
if err != nil {
|
|
fmt.Printf("Prompt failed %v\n", err)
|
|
return
|
|
}
|
|
|
|
fmt.Printf("You choose %q\n", result)
|
|
}
|
|
```
|
|
|
|
### More Examples
|
|
|
|
See full list of [examples](https://github.com/manifoldco/promptui/tree/master/_examples)
|