forked from Mirrors/bubbletea
docs(examples): filepicker AllowedTypes example (#713)
This commit is contained in:
parent
8254e0e472
commit
444e04bbb3
|
@ -1,9 +1,11 @@
|
||||||
package main
|
package main
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"errors"
|
||||||
"fmt"
|
"fmt"
|
||||||
"os"
|
"os"
|
||||||
"strings"
|
"strings"
|
||||||
|
"time"
|
||||||
|
|
||||||
"github.com/charmbracelet/bubbles/filepicker"
|
"github.com/charmbracelet/bubbles/filepicker"
|
||||||
tea "github.com/charmbracelet/bubbletea"
|
tea "github.com/charmbracelet/bubbletea"
|
||||||
|
@ -13,6 +15,15 @@ type model struct {
|
||||||
filepicker filepicker.Model
|
filepicker filepicker.Model
|
||||||
selectedFile string
|
selectedFile string
|
||||||
quitting bool
|
quitting bool
|
||||||
|
err error
|
||||||
|
}
|
||||||
|
|
||||||
|
type clearErrorMsg struct{}
|
||||||
|
|
||||||
|
func clearErrorAfter(t time.Duration) tea.Cmd {
|
||||||
|
return tea.Tick(t, func(_ time.Time) tea.Msg {
|
||||||
|
return clearErrorMsg{}
|
||||||
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
func (m model) Init() tea.Cmd {
|
func (m model) Init() tea.Cmd {
|
||||||
|
@ -27,6 +38,8 @@ func (m model) Update(msg tea.Msg) (tea.Model, tea.Cmd) {
|
||||||
m.quitting = true
|
m.quitting = true
|
||||||
return m, tea.Quit
|
return m, tea.Quit
|
||||||
}
|
}
|
||||||
|
case clearErrorMsg:
|
||||||
|
m.err = nil
|
||||||
}
|
}
|
||||||
|
|
||||||
var cmd tea.Cmd
|
var cmd tea.Cmd
|
||||||
|
@ -38,6 +51,15 @@ func (m model) Update(msg tea.Msg) (tea.Model, tea.Cmd) {
|
||||||
m.selectedFile = path
|
m.selectedFile = path
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Did the user select a disabled file?
|
||||||
|
// This is only necessary to display an error to the user.
|
||||||
|
if didSelect, path := m.filepicker.DidSelectDisabledFile(msg); didSelect {
|
||||||
|
// Let's clear the selectedFile and display an error.
|
||||||
|
m.err = errors.New(path + " is not valid.")
|
||||||
|
m.selectedFile = ""
|
||||||
|
return m, tea.Batch(cmd, clearErrorAfter(2*time.Second))
|
||||||
|
}
|
||||||
|
|
||||||
return m, cmd
|
return m, cmd
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -47,7 +69,9 @@ func (m model) View() string {
|
||||||
}
|
}
|
||||||
var s strings.Builder
|
var s strings.Builder
|
||||||
s.WriteString("\n ")
|
s.WriteString("\n ")
|
||||||
if m.selectedFile == "" {
|
if m.err != nil {
|
||||||
|
s.WriteString(m.filepicker.Styles.DisabledFile.Render(m.err.Error()))
|
||||||
|
} else if m.selectedFile == "" {
|
||||||
s.WriteString("Pick a file:")
|
s.WriteString("Pick a file:")
|
||||||
} else {
|
} else {
|
||||||
s.WriteString("Selected file: " + m.filepicker.Styles.Selected.Render(m.selectedFile))
|
s.WriteString("Selected file: " + m.filepicker.Styles.Selected.Render(m.selectedFile))
|
||||||
|
@ -58,6 +82,7 @@ func (m model) View() string {
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
fp := filepicker.New()
|
fp := filepicker.New()
|
||||||
|
fp.AllowedTypes = []string{".mod", ".sum", ".go", ".txt", ".md"}
|
||||||
fp.CurrentDirectory, _ = os.UserHomeDir()
|
fp.CurrentDirectory, _ = os.UserHomeDir()
|
||||||
|
|
||||||
m := model{
|
m := model{
|
||||||
|
|
Loading…
Reference in New Issue