2022-02-26 19:26:39 +11:00
|
|
|
package controllers
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
|
|
|
|
"github.com/jesseduffield/lazygit/pkg/gui/style"
|
|
|
|
"github.com/jesseduffield/lazygit/pkg/gui/types"
|
|
|
|
)
|
|
|
|
|
|
|
|
// this is in its own file given that the workspace controller file is already quite long
|
|
|
|
|
|
|
|
func (self *FilesController) createResetMenu() error {
|
|
|
|
red := style.FgRed
|
|
|
|
|
2022-05-08 13:30:43 +02:00
|
|
|
nukeStr := "git reset --hard HEAD && git clean -fd"
|
2022-02-26 19:26:39 +11:00
|
|
|
if len(self.model.Submodules) > 0 {
|
|
|
|
nukeStr = fmt.Sprintf("%s (%s)", nukeStr, self.c.Tr.LcAndResetSubmodules)
|
|
|
|
}
|
|
|
|
|
|
|
|
menuItems := []*types.MenuItem{
|
|
|
|
{
|
2022-05-08 14:23:32 +10:00
|
|
|
LabelColumns: []string{
|
2022-02-26 19:26:39 +11:00
|
|
|
self.c.Tr.LcDiscardAllChangesToAllFiles,
|
|
|
|
red.Sprint(nukeStr),
|
|
|
|
},
|
|
|
|
OnPress: func() error {
|
|
|
|
self.c.LogAction(self.c.Tr.Actions.NukeWorkingTree)
|
|
|
|
if err := self.git.WorkingTree.ResetAndClean(); err != nil {
|
|
|
|
return self.c.Error(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
return self.c.Refresh(types.RefreshOptions{Mode: types.ASYNC, Scope: []types.RefreshableView{types.FILES}})
|
|
|
|
},
|
2022-05-08 12:46:48 +10:00
|
|
|
Key: 'D',
|
|
|
|
Tooltip: self.c.Tr.NukeDescription,
|
2022-02-26 19:26:39 +11:00
|
|
|
},
|
|
|
|
{
|
2022-05-08 14:23:32 +10:00
|
|
|
LabelColumns: []string{
|
2022-02-26 19:26:39 +11:00
|
|
|
self.c.Tr.LcDiscardAnyUnstagedChanges,
|
|
|
|
red.Sprint("git checkout -- ."),
|
|
|
|
},
|
|
|
|
OnPress: func() error {
|
|
|
|
self.c.LogAction(self.c.Tr.Actions.DiscardUnstagedFileChanges)
|
|
|
|
if err := self.git.WorkingTree.DiscardAnyUnstagedFileChanges(); err != nil {
|
|
|
|
return self.c.Error(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
return self.c.Refresh(types.RefreshOptions{Mode: types.ASYNC, Scope: []types.RefreshableView{types.FILES}})
|
|
|
|
},
|
2022-03-27 17:19:31 +11:00
|
|
|
Key: 'u',
|
2022-02-26 19:26:39 +11:00
|
|
|
},
|
|
|
|
{
|
2022-05-08 14:23:32 +10:00
|
|
|
LabelColumns: []string{
|
2022-02-26 19:26:39 +11:00
|
|
|
self.c.Tr.LcDiscardUntrackedFiles,
|
|
|
|
red.Sprint("git clean -fd"),
|
|
|
|
},
|
|
|
|
OnPress: func() error {
|
|
|
|
self.c.LogAction(self.c.Tr.Actions.RemoveUntrackedFiles)
|
|
|
|
if err := self.git.WorkingTree.RemoveUntrackedFiles(); err != nil {
|
|
|
|
return self.c.Error(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
return self.c.Refresh(types.RefreshOptions{Mode: types.ASYNC, Scope: []types.RefreshableView{types.FILES}})
|
|
|
|
},
|
2022-03-27 17:19:31 +11:00
|
|
|
Key: 'c',
|
2022-02-26 19:26:39 +11:00
|
|
|
},
|
2022-05-08 13:30:43 +02:00
|
|
|
{
|
|
|
|
LabelColumns: []string{
|
|
|
|
self.c.Tr.LcDiscardStagedChanges,
|
|
|
|
red.Sprint("stash staged and drop stash"),
|
|
|
|
},
|
2022-05-15 12:16:20 +02:00
|
|
|
Tooltip: self.c.Tr.DiscardStagedChangesDescription,
|
2022-05-08 13:30:43 +02:00
|
|
|
OnPress: func() error {
|
|
|
|
self.c.LogAction(self.c.Tr.Actions.RemoveStagedFiles)
|
|
|
|
if !self.helpers.WorkingTree.IsWorkingTreeDirty() {
|
|
|
|
return self.c.ErrorMsg(self.c.Tr.NoTrackedStagedFilesStash)
|
|
|
|
}
|
|
|
|
if err := self.git.Stash.SaveStagedChanges("[lazygit] tmp stash"); err != nil {
|
|
|
|
return self.c.Error(err)
|
|
|
|
}
|
|
|
|
if err := self.git.Stash.DropNewest(); err != nil {
|
|
|
|
return self.c.Error(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
return self.c.Refresh(types.RefreshOptions{Mode: types.ASYNC, Scope: []types.RefreshableView{types.FILES}})
|
|
|
|
},
|
|
|
|
Key: 'S',
|
|
|
|
},
|
2022-02-26 19:26:39 +11:00
|
|
|
{
|
2022-05-08 14:23:32 +10:00
|
|
|
LabelColumns: []string{
|
2022-02-26 19:26:39 +11:00
|
|
|
self.c.Tr.LcSoftReset,
|
|
|
|
red.Sprint("git reset --soft HEAD"),
|
|
|
|
},
|
|
|
|
OnPress: func() error {
|
|
|
|
self.c.LogAction(self.c.Tr.Actions.SoftReset)
|
|
|
|
if err := self.git.WorkingTree.ResetSoft("HEAD"); err != nil {
|
|
|
|
return self.c.Error(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
return self.c.Refresh(types.RefreshOptions{Mode: types.ASYNC, Scope: []types.RefreshableView{types.FILES}})
|
|
|
|
},
|
2022-03-27 17:19:31 +11:00
|
|
|
Key: 's',
|
2022-02-26 19:26:39 +11:00
|
|
|
},
|
|
|
|
{
|
2022-05-08 14:23:32 +10:00
|
|
|
LabelColumns: []string{
|
2022-02-26 19:26:39 +11:00
|
|
|
"mixed reset",
|
|
|
|
red.Sprint("git reset --mixed HEAD"),
|
|
|
|
},
|
|
|
|
OnPress: func() error {
|
|
|
|
self.c.LogAction(self.c.Tr.Actions.MixedReset)
|
|
|
|
if err := self.git.WorkingTree.ResetMixed("HEAD"); err != nil {
|
|
|
|
return self.c.Error(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
return self.c.Refresh(types.RefreshOptions{Mode: types.ASYNC, Scope: []types.RefreshableView{types.FILES}})
|
|
|
|
},
|
2022-03-27 17:19:31 +11:00
|
|
|
Key: 'm',
|
2022-02-26 19:26:39 +11:00
|
|
|
},
|
|
|
|
{
|
2022-05-08 14:23:32 +10:00
|
|
|
LabelColumns: []string{
|
2022-02-26 19:26:39 +11:00
|
|
|
self.c.Tr.LcHardReset,
|
|
|
|
red.Sprint("git reset --hard HEAD"),
|
|
|
|
},
|
|
|
|
OnPress: func() error {
|
|
|
|
self.c.LogAction(self.c.Tr.Actions.HardReset)
|
|
|
|
if err := self.git.WorkingTree.ResetHard("HEAD"); err != nil {
|
|
|
|
return self.c.Error(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
return self.c.Refresh(types.RefreshOptions{Mode: types.ASYNC, Scope: []types.RefreshableView{types.FILES}})
|
|
|
|
},
|
2022-03-27 17:19:31 +11:00
|
|
|
Key: 'h',
|
2022-02-26 19:26:39 +11:00
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
return self.c.Menu(types.CreateMenuOptions{Title: "", Items: menuItems})
|
|
|
|
}
|