1
0
mirror of https://github.com/jesseduffield/lazygit.git synced 2025-01-18 05:17:55 +02:00
lazygit/pkg/gui/global_handlers.go

192 lines
4.6 KiB
Go
Raw Normal View History

2020-03-29 10:31:34 +11:00
package gui
import (
"fmt"
2020-03-29 10:31:34 +11:00
"strings"
2021-04-04 23:51:59 +10:00
"github.com/jesseduffield/gocui"
2022-01-08 14:00:36 +11:00
"github.com/jesseduffield/lazygit/pkg/commands/git_commands"
2022-01-28 20:44:36 +11:00
"github.com/jesseduffield/lazygit/pkg/gui/types"
2020-03-29 10:31:34 +11:00
"github.com/jesseduffield/lazygit/pkg/utils"
)
2021-11-02 20:35:53 +11:00
const HORIZONTAL_SCROLL_FACTOR = 3
2020-08-19 19:07:14 +10:00
// these views need to be re-rendered when the screen mode changes. The commits view,
// for example, will show authorship information in half and full screen mode.
2020-08-19 19:26:05 +10:00
func (gui *Gui) rerenderViewsWithScreenModeDependentContent() error {
// for now we re-render all list views.
for _, context := range gui.getListContexts() {
if err := gui.rerenderView(context.GetView()); err != nil {
2020-08-19 19:07:14 +10:00
return err
}
2020-03-29 10:31:34 +11:00
}
return nil
}
func nextIntInCycle(sl []WindowMaximisation, current WindowMaximisation) WindowMaximisation {
for i, val := range sl {
if val == current {
if i == len(sl)-1 {
return sl[0]
}
return sl[i+1]
}
}
return sl[0]
}
func prevIntInCycle(sl []WindowMaximisation, current WindowMaximisation) WindowMaximisation {
for i, val := range sl {
if val == current {
if i > 0 {
return sl[i-1]
}
return sl[len(sl)-1]
}
}
return sl[len(sl)-1]
}
func (gui *Gui) nextScreenMode() error {
gui.State.ScreenMode = nextIntInCycle([]WindowMaximisation{SCREEN_NORMAL, SCREEN_HALF, SCREEN_FULL}, gui.State.ScreenMode)
2020-08-19 19:26:05 +10:00
return gui.rerenderViewsWithScreenModeDependentContent()
}
func (gui *Gui) prevScreenMode() error {
gui.State.ScreenMode = prevIntInCycle([]WindowMaximisation{SCREEN_NORMAL, SCREEN_HALF, SCREEN_FULL}, gui.State.ScreenMode)
2020-08-19 19:07:14 +10:00
2020-08-19 19:26:05 +10:00
return gui.rerenderViewsWithScreenModeDependentContent()
2020-03-29 10:31:34 +11:00
}
2022-04-16 15:27:56 +10:00
func (gui *Gui) scrollUpView(view *gocui.View) {
view.ScrollUp(gui.c.UserConfig.Gui.ScrollHeight)
2020-03-29 10:31:34 +11:00
}
2022-04-16 15:27:56 +10:00
func (gui *Gui) scrollDownView(view *gocui.View) {
scrollHeight := gui.c.UserConfig.Gui.ScrollHeight
view.ScrollDown(scrollHeight)
2021-04-11 11:43:07 +10:00
if manager, ok := gui.viewBufferManagerMap[view.Name()]; ok {
manager.ReadLines(scrollHeight)
}
}
func (gui *Gui) scrollUpMain() error {
var view *gocui.View
if gui.c.CurrentContext().GetWindowName() == "secondary" {
view = gui.secondaryView()
} else {
view = gui.mainView()
}
if view.Name() == "mergeConflicts" {
// although we have this same logic in the controller, this method can be invoked
// via the global scroll up/down keybindings, as opposed to just the mouse wheel keybinding.
// It would be nice to have a concept of a global keybinding that runs on the top context in a
// window but that might be overkill for this one use case.
gui.State.Contexts.MergeConflicts.SetUserScrolling(true)
}
gui.scrollUpView(view)
2022-04-16 15:27:56 +10:00
return nil
2020-03-29 10:31:34 +11:00
}
func (gui *Gui) scrollDownMain() error {
var view *gocui.View
if gui.c.CurrentContext().GetWindowName() == "secondary" {
view = gui.secondaryView()
} else {
view = gui.mainView()
}
if view.Name() == "mergeConflicts" {
gui.State.Contexts.MergeConflicts.SetUserScrolling(true)
}
gui.scrollDownView(view)
2022-04-16 15:27:56 +10:00
return nil
2020-03-29 10:31:34 +11:00
}
func (gui *Gui) mainView() *gocui.View {
viewName := gui.getViewNameForWindow("main")
view, _ := gui.g.View(viewName)
return view
}
func (gui *Gui) secondaryView() *gocui.View {
viewName := gui.getViewNameForWindow("secondary")
view, _ := gui.g.View(viewName)
return view
}
func (gui *Gui) scrollUpSecondary() error {
gui.scrollUpView(gui.secondaryView())
2022-04-16 15:27:56 +10:00
return nil
2020-03-29 10:31:34 +11:00
}
func (gui *Gui) scrollDownSecondary() error {
secondaryView := gui.secondaryView()
gui.scrollDownView(secondaryView)
2022-04-16 15:27:56 +10:00
return nil
2020-03-29 10:31:34 +11:00
}
func (gui *Gui) scrollUpConfirmationPanel() error {
2021-04-04 23:51:59 +10:00
if gui.Views.Confirmation.Editable {
2020-03-29 10:31:34 +11:00
return nil
}
2022-04-16 15:27:56 +10:00
gui.scrollUpView(gui.Views.Confirmation)
return nil
2020-03-29 10:31:34 +11:00
}
func (gui *Gui) scrollDownConfirmationPanel() error {
2021-04-04 23:51:59 +10:00
if gui.Views.Confirmation.Editable {
2020-03-29 10:31:34 +11:00
return nil
}
2022-04-16 15:27:56 +10:00
gui.scrollDownView(gui.Views.Confirmation)
return nil
2020-03-29 10:31:34 +11:00
}
func (gui *Gui) handleRefresh() error {
return gui.c.Refresh(types.RefreshOptions{Mode: types.ASYNC})
2020-03-29 10:31:34 +11:00
}
2022-01-06 22:05:18 +11:00
func (gui *Gui) backgroundFetch() (err error) {
err = gui.git.Sync.Fetch(git_commands.FetchOptions{Background: true})
2022-01-06 22:05:18 +11:00
_ = gui.c.Refresh(types.RefreshOptions{Scope: []types.RefreshableView{types.BRANCHES, types.COMMITS, types.REMOTES, types.TAGS}, Mode: types.ASYNC})
2022-01-06 22:05:18 +11:00
return err
}
func (gui *Gui) handleCopySelectedSideContextItemToClipboard() error {
// important to note that this assumes we've selected an item in a side context
itemId := gui.getSideContextSelectedItemId()
if itemId == "" {
return nil
}
gui.c.LogAction(gui.c.Tr.Actions.CopyToClipboard)
2022-02-06 13:42:17 +11:00
if err := gui.os.CopyToClipboard(itemId); err != nil {
return gui.c.Error(err)
}
2020-12-24 10:21:54 +01:00
truncatedItemId := utils.TruncateWithEllipsis(strings.Replace(itemId, "\n", " ", -1), 50)
gui.c.Toast(fmt.Sprintf("'%s' %s", truncatedItemId, gui.c.Tr.LcCopiedToClipboard))
return nil
}