1package tui
 2
 3import (
 4	"fmt"
 5	"smoothie/tui/bubbles/repo"
 6	"smoothie/tui/bubbles/selection"
 7
 8	tea "github.com/charmbracelet/bubbletea"
 9	"github.com/charmbracelet/lipgloss"
10	"github.com/muesli/termenv"
11)
12
13type windowMsg struct{}
14type errMsg struct{ err error }
15
16func (e errMsg) Error() string {
17	return e.err.Error()
18}
19
20func (b *Bubble) windowChangesCmd() tea.Msg {
21	w := <-b.windowChanges
22	b.width = w.Width
23	b.height = w.Height
24	return windowMsg{}
25}
26
27func (b *Bubble) setupCmd() tea.Msg {
28	lipgloss.SetColorProfile(termenv.ANSI256)
29	b.repos = b.repoSource.AllRepos()
30	mes := make([]MenuEntry, 0)
31	rs := make([]string, 0)
32	for _, me := range b.config.Menu {
33		mes = append(mes, me)
34	}
35	if b.config.ShowAllRepos {
36	OUTER:
37		for _, r := range b.repos {
38			for _, me := range mes {
39				if r.Name == me.Repo {
40					continue OUTER
41				}
42			}
43			mes = append(mes, MenuEntry{Name: r.Name, Repo: r.Name})
44		}
45	}
46	var tmplConfig *Config
47	for _, me := range mes {
48		if me.Repo == "config" {
49			tmplConfig = b.config
50		}
51		width := b.width
52		boxLeftWidth := menuStyle.GetWidth() + menuStyle.GetHorizontalFrameSize()
53		const heightMargin = 12 // TODO: figure out why this needs to be 12
54		rb := repo.NewBubble(b.repoSource, me.Repo, width, boxLeftWidth, b.height, heightMargin, tmplConfig)
55		initCmd := rb.Init()
56		msg := initCmd()
57		switch msg := msg.(type) {
58		case repo.ErrMsg:
59			return errMsg{fmt.Errorf("missing %s: %s", me.Repo, msg.Error)}
60		}
61		me.bubble = rb
62		b.repoMenu = append(b.repoMenu, me)
63		rs = append(rs, me.Name)
64	}
65	b.repoSelect = selection.NewBubble(rs, menuItemStyle, selectedMenuItemStyle, menuCursor.String())
66	b.boxes[0] = b.repoSelect
67	/*
68		b.commitsLog = commits.NewBubble(
69			b.height-verticalPadding-2,
70			boxRightWidth-horizontalPadding-2,
71			b.repoSource.GetCommits(200),
72		)
73	*/
74	ir := -1
75	if b.initialRepo != "" {
76		for i, me := range b.repoMenu {
77			if me.Repo == b.initialRepo {
78				ir = i
79			}
80		}
81	}
82	if ir == -1 {
83		b.boxes[1] = b.repoMenu[0].bubble
84		b.activeBox = 0
85	} else {
86		b.boxes[1] = b.repoMenu[ir].bubble
87		b.repoSelect.SelectedItem = ir
88		b.activeBox = 1
89	}
90	b.state = loadedState
91	return nil
92}