Skip to content

Commit

Permalink
feat: Trigger actions from the help dialog
Browse files Browse the repository at this point in the history
  • Loading branch information
F1bonacc1 committed Sep 28, 2024
1 parent 33435d8 commit b43369f
Show file tree
Hide file tree
Showing 2 changed files with 28 additions and 12 deletions.
38 changes: 27 additions & 11 deletions src/tui/help-dialog.go
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ package tui
import (
"fmt"
"github.com/f1bonacc1/process-compose/src/config"
"github.com/gdamore/tcell/v2"
"github.com/rivo/tview"
)

Expand All @@ -20,11 +21,18 @@ type helpDialog struct {
func newHelpDialog(shortcuts *ShortCuts, closeFn func()) *helpDialog {
dialog := &helpDialog{
Grid: tview.NewGrid().SetBorders(true).SetRows(30, 1),
table: createHelpTable(shortcuts),
table: createHelpTable(shortcuts, closeFn),
closeButton: tview.NewButton("Close").SetSelectedFunc(closeFn),
}
dialog.AddItem(dialog.table, 0, 0, 1, 1, 0, 0, false).
AddItem(dialog.closeButton, 1, 0, 1, 1, 0, 0, true)
dialog.SetInputCapture(func(event *tcell.EventKey) *tcell.EventKey {
if event.Key() == tcell.KeyEscape {
closeFn()
return nil
}
return event
})
dialog.AddItem(dialog.table, 0, 0, 1, 1, 0, 0, true).
AddItem(dialog.closeButton, 1, 0, 1, 1, 0, 0, false)
return dialog
}

Expand Down Expand Up @@ -55,19 +63,19 @@ func (hd *helpDialog) StylesChanged(s *config.Styles) {
}
}

func createHelpTable(shortcuts *ShortCuts) *tview.Table {
table := tview.NewTable().SetBorders(false).SetSelectable(false, false)
func createHelpTable(shortcuts *ShortCuts, fn func()) *tview.Table {
table := tview.NewTable().SetBorders(false).SetSelectable(true, false)

row := 0
//GENERAL
for _, act := range generalActionsOrder {
action := shortcuts.ShortCutKeys[act]
table.SetCell(row, 0, tview.NewTableCell(action.ShortCut).SetSelectable(false))
if len(action.Description) > 0 {
table.SetCell(row, 1, tview.NewTableCell(action.Description).SetSelectable(false).SetExpansion(1))
table.SetCell(row, 1, tview.NewTableCell(action.Description).SetSelectable(true).SetExpansion(1).SetReference(act))
} else {
td := fmt.Sprintf("%s/%s", action.ToggleDescription[true], action.ToggleDescription[false])
table.SetCell(row, 1, tview.NewTableCell(td).SetSelectable(false).SetExpansion(1))
table.SetCell(row, 1, tview.NewTableCell(td).SetSelectable(true).SetExpansion(1).SetReference(act))
}
row++
}
Expand All @@ -83,10 +91,10 @@ func createHelpTable(shortcuts *ShortCuts) *tview.Table {
action := shortcuts.ShortCutKeys[act]
table.SetCell(row, 0, tview.NewTableCell(action.ShortCut).SetSelectable(false))
if len(action.Description) > 0 {
table.SetCell(row, 1, tview.NewTableCell(action.Description).SetSelectable(false).SetExpansion(1))
table.SetCell(row, 1, tview.NewTableCell(action.Description).SetSelectable(true).SetExpansion(1).SetReference(act))
} else {
td := fmt.Sprintf("%s/%s", action.ToggleDescription[true], action.ToggleDescription[false])
table.SetCell(row, 1, tview.NewTableCell(td).SetSelectable(false).SetExpansion(1))
table.SetCell(row, 1, tview.NewTableCell(td).SetSelectable(true).SetExpansion(1).SetReference(act))
}
row++
}
Expand All @@ -98,15 +106,23 @@ func createHelpTable(shortcuts *ShortCuts) *tview.Table {
action := shortcuts.ShortCutKeys[act]
table.SetCell(row, 0, tview.NewTableCell(action.ShortCut).SetSelectable(false))
if len(action.Description) > 0 {
table.SetCell(row, 1, tview.NewTableCell(action.Description).SetSelectable(false).SetExpansion(1))
table.SetCell(row, 1, tview.NewTableCell(action.Description).SetSelectable(true).SetExpansion(1).SetReference(act))
} else {
td := fmt.Sprintf("%s/%s", action.ToggleDescription[true], action.ToggleDescription[false])
table.SetCell(row, 1, tview.NewTableCell(td).SetSelectable(false).SetExpansion(1))
table.SetCell(row, 1, tview.NewTableCell(td).SetSelectable(true).SetExpansion(1).SetReference(act))
}
row++
}

table.SetBorder(true).SetTitle("Shortcuts")
table.SetInputCapture(func(event *tcell.EventKey) *tcell.EventKey {
if event.Key() == tcell.KeyEnter {
act := table.GetCell(table.GetSelection()).GetReference().(ActionName)
fn()
shortcuts.ShortCutKeys[act].actionFn()
}
return event
})

return table
}
2 changes: 1 addition & 1 deletion src/tui/view.go
Original file line number Diff line number Diff line change
Expand Up @@ -221,7 +221,7 @@ func (pv *pcView) setShortCutsActions() {
pv.updateHelpTextView()
})
pv.shortcuts.setAction(ActionHelp, func() {
pv.showDialog(pv.helpDialog, 50, 32)
pv.showDialog(pv.helpDialog, 50, 33)
})
pv.shortcuts.setAction(ActionThemeSelector, pv.showThemeSelector)
pv.shortcuts.setAction(ActionSendToBackground, pv.runShellProcess)
Expand Down

0 comments on commit b43369f

Please sign in to comment.