summaryrefslogtreecommitdiff
path: root/internal/switcher
diff options
context:
space:
mode:
authorBenjamin Chausse <benjamin@chausse.xyz>2024-12-28 00:46:18 -0500
committerBenjamin Chausse <benjamin@chausse.xyz>2024-12-28 00:46:18 -0500
commit101e23780e5f8bc97f5683f5901fbd31f56ce29e (patch)
tree59a67abf320f8b77440cc7597331796f8b4a57a9 /internal/switcher
parent914633df3e8da138bc2ac78f69fe340832e2283d (diff)
First attempt at auto-resize
Diffstat (limited to 'internal/switcher')
-rw-r--r--internal/switcher/switcher.go47
1 files changed, 43 insertions, 4 deletions
diff --git a/internal/switcher/switcher.go b/internal/switcher/switcher.go
index 8de31c6..cf16b6a 100644
--- a/internal/switcher/switcher.go
+++ b/internal/switcher/switcher.go
@@ -32,6 +32,7 @@ type Model struct {
input textinput.Model
notices notices.Model
fullHelp bool // When false, only show help for the switcher (not children)
+ h, w int
}
func New() Model {
@@ -101,6 +102,9 @@ func (m Model) Init() tea.Cmd {
}
func (m Model) View() string {
+ pickerStr := m.pickers[m.active].View()
+ w := lipgloss.Width(pickerStr)
+
tabs := make([]string, len(m.pickers))
for i, p := range m.pickers {
if i == m.active {
@@ -115,9 +119,6 @@ func (m Model) View() string {
ui.Style().TabGeom.Render(ui.TabSepRight),
}, " ")
- pickerStr := m.pickers[m.active].View()
- w := lipgloss.Width(pickerStr)
-
m.preview.SetWidth(w)
previewStr := m.preview.View()
@@ -147,13 +148,27 @@ func (m Model) View() string {
helpStr,
}, "\n"))
- return strings.Join(
+ viewStr := strings.Join(
[]string{
tabStr,
mainArea,
inputStr,
m.notices.View(),
}, "\n")
+
+ // if lipgloss.Width(viewStr) > m.w {
+ // return ui.Style().TooSmall.
+ // Align(lipgloss.Center).
+ // Width(m.w).
+ // Height(m.h).
+ // Render("Terminal too small!\nPlease increase terminal size...")
+ // }
+
+ return lipgloss.NewStyle().
+ // Align(lipgloss.Center).
+ // Width(m.w).
+ // Height(m.h).
+ Render(viewStr)
}
func (m Model) Update(msg tea.Msg) (tea.Model, tea.Cmd) {
@@ -166,6 +181,30 @@ func (m Model) Update(msg tea.Msg) (tea.Model, tea.Cmd) {
m.notices = newNotices.(notices.Model)
cmds = append(cmds, cmd)
+ case tea.WindowSizeMsg:
+ m.w = msg.Width
+ m.h = msg.Height
+ for i, p := range m.pickers {
+ var cmd tea.Cmd
+ var model tea.Model
+ model, cmd = p.Update(msg)
+ m.pickers[i] = model.(picker.Model)
+ cmds = append(cmds, cmd)
+ }
+ // iterate over every model contained in the model using a struct
+ // assign the new model to the model and append the command to the commands
+ // return the model and the batched commands
+ newInput, cmd := m.input.Update(msg)
+ m.input = newInput
+ cmds = append(cmds, cmd)
+ newPreview, cmd := m.preview.Update(msg)
+ m.preview = newPreview.(preview.Model)
+ cmds = append(cmds, cmd)
+ newNotices, cmd := m.notices.Update(msg)
+ m.notices = newNotices.(notices.Model)
+ cmds = append(cmds, cmd)
+ return m, tea.Batch(cmds...)
+
case tea.KeyMsg:
if m.input.Focused() && msg.String() != "ctrl+c" {