summaryrefslogtreecommitdiffstats
path: root/pkg/gui/commit_files_panel.go
diff options
context:
space:
mode:
Diffstat (limited to 'pkg/gui/commit_files_panel.go')
-rw-r--r--pkg/gui/commit_files_panel.go210
1 files changed, 16 insertions, 194 deletions
diff --git a/pkg/gui/commit_files_panel.go b/pkg/gui/commit_files_panel.go
index df37f6b41..be8ec1a53 100644
--- a/pkg/gui/commit_files_panel.go
+++ b/pkg/gui/commit_files_panel.go
@@ -2,10 +2,8 @@ package gui
import (
"github.com/jesseduffield/lazygit/pkg/commands/models"
- "github.com/jesseduffield/lazygit/pkg/commands/patch"
"github.com/jesseduffield/lazygit/pkg/gui/context"
"github.com/jesseduffield/lazygit/pkg/gui/controllers"
- "github.com/jesseduffield/lazygit/pkg/gui/types"
)
func (gui *Gui) getSelectedCommitFile() *models.CommitFile {
@@ -37,7 +35,7 @@ func (gui *Gui) commitFilesRenderToMain() error {
}
to := gui.State.Contexts.CommitFiles.GetRefName()
- from, reverse := gui.getFromAndReverseArgsForDiff(to)
+ from, reverse := gui.State.Modes.Diffing.GetFromAndReverseArgsForDiff(to)
cmdObj := gui.git.WorkingTree.ShowFileDiffCmdObj(from, to, reverse, node.GetPath(), false)
task := NewRunPtyTask(cmdObj.GetCmd())
@@ -57,43 +55,22 @@ func (gui *Gui) commitFilesRenderToMain() error {
})
}
-func (gui *Gui) handleCheckoutCommitFile() error {
- node := gui.State.Contexts.CommitFiles.GetSelectedFileNode()
- if node == nil {
- return nil
- }
-
- gui.c.LogAction(gui.c.Tr.Actions.CheckoutFile)
- if err := gui.git.WorkingTree.CheckoutFile(gui.State.Contexts.CommitFiles.GetRefName(), node.GetPath()); err != nil {
- return gui.c.Error(err)
- }
+func (gui *Gui) SwitchToCommitFilesContext(opts controllers.SwitchToCommitFilesContextOpts) error {
+ // sometimes the commitFiles view is already shown in another window, so we need to ensure that window
+ // no longer considers the commitFiles view as its main view.
+ gui.resetWindowContext(gui.State.Contexts.CommitFiles)
- return gui.c.Refresh(types.RefreshOptions{Mode: types.ASYNC})
-}
+ gui.State.Contexts.CommitFiles.SetSelectedLineIdx(0)
+ gui.State.Contexts.CommitFiles.SetRefName(opts.RefName)
+ gui.State.Contexts.CommitFiles.SetCanRebase(opts.CanRebase)
+ gui.State.Contexts.CommitFiles.SetParentContext(opts.Context)
+ gui.State.Contexts.CommitFiles.SetWindowName(opts.Context.GetWindowName())
-func (gui *Gui) handleDiscardOldFileChange() error {
- if ok, err := gui.validateNormalWorkingTreeState(); !ok {
+ if err := gui.refreshCommitFilesView(); err != nil {
return err
}
- fileName := gui.getSelectedCommitFileName()
-
- return gui.c.Ask(types.AskOpts{
- Title: gui.c.Tr.DiscardFileChangesTitle,
- Prompt: gui.c.Tr.DiscardFileChangesPrompt,
- HandleConfirm: func() error {
- return gui.c.WithWaitingStatus(gui.c.Tr.RebasingStatus, func() error {
- gui.c.LogAction(gui.c.Tr.Actions.DiscardOldFileChange)
- if err := gui.git.Rebase.DiscardOldFileChanges(gui.State.Model.Commits, gui.State.Contexts.LocalCommits.GetSelectedLineIdx(), fileName); err != nil {
- if err := gui.helpers.MergeAndRebase.CheckMergeOrRebase(err); err != nil {
- return err
- }
- }
-
- return gui.c.Refresh(types.RefreshOptions{Mode: types.BLOCK_UI})
- })
- },
- })
+ return gui.c.PushContext(gui.State.Contexts.CommitFiles)
}
func (gui *Gui) refreshCommitFilesView() error {
@@ -105,7 +82,7 @@ func (gui *Gui) refreshCommitFilesView() error {
}
to := gui.State.Contexts.CommitFiles.GetRefName()
- from, reverse := gui.getFromAndReverseArgsForDiff(to)
+ from, reverse := gui.State.Modes.Diffing.GetFromAndReverseArgsForDiff(to)
files, err := gui.git.Loaders.CommitFiles.GetFilesInDiff(from, to, reverse)
if err != nil {
@@ -117,166 +94,11 @@ func (gui *Gui) refreshCommitFilesView() error {
return gui.c.PostRefreshUpdate(gui.State.Contexts.CommitFiles)
}
-func (gui *Gui) handleOpenOldCommitFile() error {
+func (gui *Gui) getSelectedCommitFileName() string {
node := gui.State.Contexts.CommitFiles.GetSelectedFileNode()
if node == nil {
- return nil
- }
-
- return gui.helpers.Files.OpenFile(node.GetPath())
-}
-
-func (gui *Gui) handleEditCommitFile() error {
- node := gui.State.Contexts.CommitFiles.GetSelectedFileNode()
- if node == nil {
- return nil
- }
-
- if node.File == nil {
- return gui.c.ErrorMsg(gui.c.Tr.ErrCannotEditDirectory)
- }
-
- return gui.helpers.Files.EditFile(node.GetPath())
-}
-
-func (gui *Gui) handleToggleFileForPatch() error {
- node := gui.State.Contexts.CommitFiles.GetSelectedFileNode()
- if node == nil {
- return nil
- }
-
- toggleTheFile := func() error {
- if !gui.git.Patch.PatchManager.Active() {
- if err := gui.startPatchManager(); err != nil {
- return err
- }
- }
-
- // if there is any file that hasn't been fully added we'll fully add everything,
- // otherwise we'll remove everything
- adding := node.AnyFile(func(file *models.CommitFile) bool {
- return gui.git.Patch.PatchManager.GetFileStatus(file.Name, gui.State.Contexts.CommitFiles.GetRefName()) != patch.WHOLE
- })
-
- err := node.ForEachFile(func(file *models.CommitFile) error {
- if adding {
- return gui.git.Patch.PatchManager.AddFileWhole(file.Name)
- } else {
- return gui.git.Patch.PatchManager.RemoveFile(file.Name)
- }
- })
-
- if err != nil {
- return gui.c.Error(err)
- }
-
- if gui.git.Patch.PatchManager.IsEmpty() {
- gui.git.Patch.PatchManager.Reset()
- }
-
- return gui.c.PostRefreshUpdate(gui.State.Contexts.CommitFiles)
- }
-
- if gui.git.Patch.PatchManager.Active() && gui.git.Patch.PatchManager.To != gui.State.Contexts.CommitFiles.GetRefName() {
- return gui.c.Ask(types.AskOpts{
- Title: gui.c.Tr.DiscardPatch,
- Prompt: gui.c.Tr.DiscardPatchConfirm,
- HandleConfirm: func() error {
- gui.git.Patch.PatchManager.Reset()
- return toggleTheFile()
- },
- })
- }
-
- return toggleTheFile()
-}
-
-func (gui *Gui) startPatchManager() error {
- commitFilesContext := gui.State.Contexts.CommitFiles
-
- canRebase := commitFilesContext.GetCanRebase()
- to := commitFilesContext.GetRefName()
-
- from, reverse := gui.getFromAndReverseArgsForDiff(to)
-
- gui.git.Patch.PatchManager.Start(from, to, reverse, canRebase)
- return nil
-}
-
-func (gui *Gui) handleEnterCommitFile() error {
- return gui.enterCommitFile(types.OnFocusOpts{ClickedViewName: "", ClickedViewLineIdx: -1})
-}
-
-func (gui *Gui) enterCommitFile(opts types.OnFocusOpts) error {
- node := gui.State.Contexts.CommitFiles.GetSelectedFileNode()
- if node == nil {
- return nil
- }
-
- if node.File == nil {
- return gui.handleToggleCommitFileDirCollapsed()
- }
-
- enterTheFile := func() error {
- if !gui.git.Patch.PatchManager.Active() {
- if err := gui.startPatchManager(); err != nil {
- return err
- }
- }
-
- return gui.c.PushContext(gui.State.Contexts.PatchBuilding, opts)
- }
-
- if gui.git.Patch.PatchManager.Active() && gui.git.Patch.PatchManager.To != gui.State.Contexts.CommitFiles.GetRefName() {
- return gui.c.Ask(types.AskOpts{
- Title: gui.c.Tr.DiscardPatch,
- Prompt: gui.c.Tr.DiscardPatchConfirm,
- HandleConfirm: func() error {
- gui.git.Patch.PatchManager.Reset()
- return enterTheFile()
- },
- })
- }
-
- return enterTheFile()
-}
-
-func (gui *Gui) handleToggleCommitFileDirCollapsed() error {
- node := gui.State.Contexts.CommitFiles.GetSelectedFileNode()
- if node == nil {
- return nil
- }
-
- gui.State.Contexts.CommitFiles.CommitFileTreeViewModel.ToggleCollapsed(node.GetPath())
-
- if err := gui.c.PostRefreshUpdate(gui.State.Contexts.CommitFiles); err != nil {
- gui.c.Log.Error(err)
- }
-
- return nil
-}
-
-// NOTE: this is very similar to handleToggleFileTreeView, could be DRY'd with generics
-func (gui *Gui) handleToggleCommitFileTreeView() error {
- gui.State.Contexts.CommitFiles.CommitFileTreeViewModel.ToggleShowTree()
-
- return gui.c.PostRefreshUpdate(gui.State.Contexts.CommitFiles)
-}
-
-func (gui *Gui) SwitchToCommitFilesContext(opts controllers.SwitchToCommitFilesContextOpts) error {
- // sometimes the commitFiles view is already shown in another window, so we need to ensure that window
- // no longer considers the commitFiles view as its main view.
- gui.resetWindowContext(gui.State.Contexts.CommitFiles)
-
- gui.State.Contexts.CommitFiles.SetSelectedLineIdx(0)
- gui.State.Contexts.CommitFiles.SetRefName(opts.RefName)
- gui.State.Contexts.CommitFiles.SetCanRebase(opts.CanRebase)
- gui.State.Contexts.CommitFiles.SetParentContext(opts.Context)
- gui.State.Contexts.CommitFiles.SetWindowName(opts.Context.GetWindowName())
-
- if err := gui.refreshCommitFilesView(); err != nil {
- return err
+ return ""
}
- return gui.c.PushContext(gui.State.Contexts.CommitFiles)
+ return node.Path
}