refactor: add cards to card column inside newColumn()

This commit is contained in:
Dan Anglin 2023-04-25 04:57:24 +01:00
parent 3536c930f4
commit 0e7cb2388d
Signed by: dananglin
GPG key ID: 0C1D44CFBEE68638
2 changed files with 35 additions and 33 deletions

View file

@ -15,17 +15,17 @@ type column struct {
cards *tview.List
}
func (u *UI) newColumn(statusID int, statusName string) column {
cards := tview.NewList()
func (u *UI) newColumn(status board.Status) (column, error) {
cardList := tview.NewList()
cards.SetBorder(true)
cards.ShowSecondaryText(false)
cards.SetTitle(" " + statusName + " ")
cards.SetHighlightFullLine(true)
cards.SetSelectedFocusOnly(true)
cards.SetWrapAround(false)
cardList.SetBorder(true)
cardList.ShowSecondaryText(false)
cardList.SetTitle(" " + status.Name + " ")
cardList.SetHighlightFullLine(true)
cardList.SetSelectedFocusOnly(true)
cardList.SetWrapAround(false)
cards.SetInputCapture(func(event *tcell.EventKey) *tcell.EventKey {
cardList.SetInputCapture(func(event *tcell.EventKey) *tcell.EventKey {
switch event.Rune() {
case 'q':
u.pages.ShowPage(quitPageName)
@ -38,29 +38,42 @@ func (u *UI) newColumn(statusID int, statusName string) column {
case 'l':
u.shiftColumnFocus(shiftRight)
case 'j':
cur := cards.GetCurrentItem()
if cur == cards.GetItemCount()-1 {
cur := cardList.GetCurrentItem()
if cur == cardList.GetItemCount()-1 {
cur = 0
} else {
cur++
}
cards.SetCurrentItem(cur)
cardList.SetCurrentItem(cur)
case 'k':
cur := cards.GetCurrentItem()
cur := cardList.GetCurrentItem()
cur--
cards.SetCurrentItem(cur)
cardList.SetCurrentItem(cur)
}
return event
})
c := column{
statusID: statusID,
statusName: statusName,
cards: cards,
if len(status.CardIds) > 0 {
cards, err := u.board.CardList(status.CardIds)
if err != nil {
return column{}, fmt.Errorf("unable to get the card list. %w", err)
}
for _, c := range cards {
cardList.AddItem(fmt.Sprintf("[%d] %s", c.Id(), c.Title), "", 0, nil)
}
}
return c
u.flex.AddItem(cardList, 0, 1, false)
c := column{
statusID: status.ID,
statusName: status.Name,
cards: cardList,
}
return c, nil
}
func (u *UI) setColumnFocus() {
@ -92,20 +105,7 @@ func (u *UI) updateColumns(statusList []board.Status) error {
columns := make([]column, len(statusList))
for i := range statusList {
columns[i] = u.newColumn(statusList[i].ID, statusList[i].Name)
if len(statusList[i].CardIds) > 0 {
cards, err := u.board.CardList(statusList[i].CardIds)
if err != nil {
return fmt.Errorf("unable to get the card list. %w", err)
}
for _, c := range cards {
columns[i].cards.AddItem(fmt.Sprintf("[%d] %s", c.Id(), c.Title), "", 0, nil)
}
}
u.flex.AddItem(columns[i].cards, 0, 1, false)
columns[i], _ = u.newColumn(statusList[i])
}
u.columns = columns

View file

@ -149,6 +149,8 @@ func (u *UI) refresh() error {
u.setColumnFocus()
// TODO: update move status page here
return nil
}