emdb/terminal-client/tui/basemodel.go

126 lines
3.3 KiB
Go
Raw Normal View History

2023-12-23 18:43:38 +01:00
package tui
import (
"fmt"
"strings"
2024-03-08 09:25:02 +01:00
"code.ewintr.nl/emdb/client"
"code.ewintr.nl/emdb/job"
"code.ewintr.nl/emdb/storage"
2023-12-23 18:43:38 +01:00
"github.com/charmbracelet/bubbles/viewport"
tea "github.com/charmbracelet/bubbletea"
)
type baseModel struct {
2024-03-09 13:18:51 +01:00
movieRepo *storage.MovieRepository
reviewRepo *storage.ReviewRepository
jobQueue *job.JobQueue
tmdb *client.TMDB
2023-12-24 13:33:15 +01:00
tabs *TabSet
2023-12-24 10:16:11 +01:00
initialized bool
logger *Logger
2023-12-23 18:43:38 +01:00
logViewport viewport.Model
windowSize tea.WindowSizeMsg
contentSize tea.WindowSizeMsg
}
2024-03-09 13:18:51 +01:00
func NewBaseModel(movieRepo *storage.MovieRepository, reviewRepo *storage.ReviewRepository, jobQueue *job.JobQueue, tmdb *client.TMDB, logger *Logger) (tea.Model, tea.Cmd) {
2023-12-24 10:16:11 +01:00
logViewport := viewport.New(0, 0)
logViewport.KeyMap = viewport.KeyMap{}
m := baseModel{
movieRepo: movieRepo,
reviewRepo: reviewRepo,
jobQueue: jobQueue,
tmdb: tmdb,
2023-12-24 13:33:15 +01:00
tabs: NewTabSet(),
2023-12-24 10:16:11 +01:00
logViewport: logViewport,
logger: logger,
2023-12-24 10:16:11 +01:00
}
m.setSize()
return m, nil
}
2023-12-23 18:43:38 +01:00
func (m baseModel) Init() tea.Cmd {
return nil
}
func (m baseModel) Update(msg tea.Msg) (tea.Model, tea.Cmd) {
var cmd tea.Cmd
var cmds []tea.Cmd
switch msg := msg.(type) {
2023-12-27 08:25:09 +01:00
case NextTabSelected:
m.tabs.Next()
case PrevTabSelected:
m.tabs.Previous()
2023-12-23 18:43:38 +01:00
case tea.WindowSizeMsg:
m.windowSize = msg
2023-12-24 10:16:11 +01:00
if !m.initialized {
2023-12-24 13:33:15 +01:00
var emdbTab, tmdbTab tea.Model
emdbTab, cmd = NewTabEMDB(m.movieRepo, m.logger)
2023-12-24 13:33:15 +01:00
cmds = append(cmds, cmd)
tmdbTab, cmd = NewTabTMDB(m.movieRepo, m.jobQueue, m.tmdb, m.logger)
2023-12-24 10:16:11 +01:00
cmds = append(cmds, cmd)
reviewTab, cmd := NewTabReview(m.reviewRepo, m.logger)
2024-01-06 14:49:45 +01:00
cmds = append(cmds, cmd)
2023-12-25 13:29:43 +01:00
m.tabs.AddTab("emdb", "Watched movies", emdbTab)
2024-01-06 14:49:45 +01:00
m.tabs.AddTab("review", "Review", reviewTab)
2023-12-24 13:33:15 +01:00
m.tabs.AddTab("tmdb", "TMDB", tmdbTab)
2023-12-24 10:16:11 +01:00
m.initialized = true
2023-12-23 18:43:38 +01:00
}
m.Log(fmt.Sprintf("new window size: %dx%d", msg.Width, msg.Height))
2023-12-23 18:43:38 +01:00
m.setSize()
2023-12-25 13:29:43 +01:00
tabSize := TabSizeMsg{
2023-12-23 18:43:38 +01:00
Width: m.contentSize.Width,
Height: m.contentSize.Height,
}
2023-12-24 13:33:15 +01:00
cmds = append(cmds, m.tabs.Update(tabSize))
2023-12-25 09:21:00 +01:00
case NewMovie:
m.Log(fmt.Sprintf("imported movie %s", msg.m.Title))
2023-12-25 13:29:43 +01:00
m.tabs.Select("emdb")
cmds = append(cmds, FetchMovieList(m.movieRepo))
2023-12-24 17:11:29 +01:00
case error:
m.Log(fmt.Sprintf("ERROR: %s", msg.Error()))
2023-12-24 13:33:15 +01:00
default:
cmds = append(cmds, m.tabs.Update(msg))
2023-12-23 18:43:38 +01:00
}
m.logViewport.SetContent(strings.Join(m.logger.Lines, "\n"))
2023-12-23 18:43:38 +01:00
m.logViewport.GotoBottom()
m.logViewport, cmd = m.logViewport.Update(msg)
return m, tea.Batch(cmds...)
}
func (m *baseModel) Log(msg string) {
m.logger.Log(msg)
}
2023-12-23 18:43:38 +01:00
func (m baseModel) View() string {
2023-12-24 10:16:11 +01:00
if !m.initialized {
2023-12-23 18:43:38 +01:00
return "\n Initializing..."
}
2024-01-14 12:07:25 +01:00
logWindow := windowStyle.
Width(m.contentSize.Width).
Height(logLineCount).
//Background(lipgloss.ANSIColor(termenv.ANSIYellow)).
Render(m.logViewport.View())
return fmt.Sprintf("%s\n%s", m.tabs.View(), logWindow)
2023-12-23 18:43:38 +01:00
}
func (m *baseModel) setSize() {
2024-01-14 12:07:25 +01:00
logHeight := logLineCount
2023-12-23 18:43:38 +01:00
menuHeight := 1
2024-01-14 12:07:25 +01:00
m.contentSize.Width = m.windowSize.Width - windowStyle.GetHorizontalFrameSize()
m.contentSize.Height = m.windowSize.Height - windowStyle.GetVerticalFrameSize() - logHeight - menuHeight
//m.Log(fmt.Sprintf("contentheight: %d = windowheight %d - windowframeheight %d - logheight %d - menuheight %d", m.contentSize.Height, m.windowSize.Height, windowStyle.GetVerticalFrameSize(), logHeight, menuHeight))
2023-12-23 18:43:38 +01:00
m.logViewport.Width = m.contentSize.Width
m.logViewport.Height = logLineCount
}