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 := b.styles.Menu.GetWidth() + b.styles.Menu.GetHorizontalFrameSize()
53 // TODO: also send this along with a tea.WindowSizeMsg
54 var heightMargin = lipgloss.Height(b.headerView()) +
55 lipgloss.Height(b.footerView()) +
56 b.styles.RepoBody.GetVerticalFrameSize() +
57 b.styles.App.GetVerticalMargins() +
58 3 // TODO: make this dynamic (this is the height of the repo info)
59 rb := repo.NewBubble(b.repoSource, me.Repo, b.styles, width, boxLeftWidth, b.height, heightMargin, tmplConfig)
60 rb.Host = b.config.Host
61 rb.Port = b.config.Port
62 initCmd := rb.Init()
63 msg := initCmd()
64 switch msg := msg.(type) {
65 case repo.ErrMsg:
66 return errMsg{fmt.Errorf("missing %s: %s", me.Repo, msg.Error)}
67 }
68 me.bubble = rb
69 b.repoMenu = append(b.repoMenu, me)
70 rs = append(rs, me.Name)
71 }
72 b.repoSelect = selection.NewBubble(rs, b.styles)
73 b.boxes[0] = b.repoSelect
74 /*
75 b.commitsLog = commits.NewBubble(
76 b.height-verticalPadding-2,
77 boxRightWidth-horizontalPadding-2,
78 b.repoSource.GetCommits(200),
79 )
80 */
81 ir := -1
82 if b.initialRepo != "" {
83 for i, me := range b.repoMenu {
84 if me.Repo == b.initialRepo {
85 ir = i
86 }
87 }
88 }
89 if ir == -1 {
90 b.boxes[1] = b.repoMenu[0].bubble
91 b.activeBox = 0
92 } else {
93 b.boxes[1] = b.repoMenu[ir].bubble
94 b.repoSelect.SelectedItem = ir
95 b.activeBox = 1
96 }
97 b.state = loadedState
98 return nil
99}