Skip to content

Commit

Permalink
Fix #315: Pre-select most recent playlist in "Add to playlist" dialog
Browse files Browse the repository at this point in the history
  • Loading branch information
dweymouth committed Jan 20, 2024
1 parent e1bc745 commit edc3ef7
Show file tree
Hide file tree
Showing 3 changed files with 22 additions and 4 deletions.
1 change: 1 addition & 0 deletions backend/config.go
Original file line number Diff line number Diff line change
Expand Up @@ -42,6 +42,7 @@ type AppConfig struct {
AllowMultiInstance bool
MaxImageCacheSizeMB int
SavePlayQueue bool
DefaultPlaylistID string

// Experimental - may be removed in future
FontNormalTTF string
Expand Down
13 changes: 10 additions & 3 deletions ui/controller/controller.go
Original file line number Diff line number Diff line change
Expand Up @@ -272,12 +272,17 @@ func (m *Controller) DoAddTracksToPlaylistWorkflow(trackIDs []string) {
log.Printf("error getting user-owned playlists: %s", err.Error())
return
}

selectedIdx := -1
plNames := make([]string, 0, len(pls))
for _, pl := range pls {
for i, pl := range pls {
plNames = append(plNames, pl.Name)
if defId := m.App.Config.Application.DefaultPlaylistID; defId != "" && pl.ID == defId {
selectedIdx = i
}
}

dlg := dialogs.NewAddToPlaylistDialog("Add to Playlist", plNames)
dlg := dialogs.NewAddToPlaylistDialog("Add to Playlist", plNames, selectedIdx)
pop := widget.NewModalPopUp(dlg, m.MainWindow.Canvas())
m.ClosePopUpOnEscape(pop)
dlg.OnCanceled = pop.Hide
Expand All @@ -287,8 +292,10 @@ func (m *Controller) DoAddTracksToPlaylistWorkflow(trackIDs []string) {
if playlistChoice < 0 {
go m.App.ServerManager.Server.CreatePlaylist(newPlaylistName, trackIDs)
} else {
playlist := pls[playlistChoice]
m.App.Config.Application.DefaultPlaylistID = playlist.ID
go m.App.ServerManager.Server.AddPlaylistTracks(
pls[playlistChoice].ID, trackIDs)
playlist.ID, trackIDs)
}
}
m.haveModal = true
Expand Down
12 changes: 11 additions & 1 deletion ui/dialogs/addtoplaylistdialog.go
Original file line number Diff line number Diff line change
@@ -1,6 +1,8 @@
package dialogs

import (
"time"

"fyne.io/fyne/v2"
"fyne.io/fyne/v2/container"
"fyne.io/fyne/v2/layout"
Expand All @@ -23,7 +25,7 @@ type AddToPlaylistDialog struct {

var _ fyne.Widget = (*AddToPlaylistDialog)(nil)

func NewAddToPlaylistDialog(title string, existingPlaylistNames []string) *AddToPlaylistDialog {
func NewAddToPlaylistDialog(title string, existingPlaylistNames []string, selectedIdx int) *AddToPlaylistDialog {
a := &AddToPlaylistDialog{}
a.ExtendBaseWidget(a)

Expand All @@ -35,6 +37,14 @@ func NewAddToPlaylistDialog(title string, existingPlaylistNames []string) *AddTo
a.onSelectionChanged()
})
a.playlistSelect.PlaceHolder = "(Choose playlist)"
if selectedIdx >= 0 {
// calling SetSelectedIndex before showing the Select crashes...
go func() {
time.Sleep(10 * time.Millisecond)
// add 1 to selectedIdx to account for "(Choose playlist)" entry
a.playlistSelect.SetSelectedIndex(selectedIdx + 1)
}()
}
a.newPlaylistName = widget.NewEntry()
a.newPlaylistName.Hidden = true
a.newPlaylistName.OnChanged = func(text string) {
Expand Down

0 comments on commit edc3ef7

Please sign in to comment.