Playlists pinned by saving the server information

This commit is contained in:
CappielloAntonio 2021-12-05 16:55:47 +01:00
parent a1885e96cd
commit 08c1b03d84
8 changed files with 29 additions and 10 deletions

View file

@ -20,7 +20,7 @@ import com.cappielloantonio.play.model.Server;
@SuppressLint("RestrictedApi") @SuppressLint("RestrictedApi")
@Database( @Database(
version = 25, version = 26,
entities = {Queue.class, Server.class, RecentSearch.class, Download.class, Playlist.class} entities = {Queue.class, Server.class, RecentSearch.class, Download.class, Playlist.class}
// autoMigrations = { @AutoMigration(from = 23, to = 24) } // autoMigrations = { @AutoMigration(from = 23, to = 24) }
) )

View file

@ -13,8 +13,8 @@ import java.util.List;
@Dao @Dao
public interface PlaylistDao { public interface PlaylistDao {
@Query("SELECT * FROM playlist") @Query("SELECT * FROM playlist WHERE server=:serverId")
LiveData<List<Playlist>> getAll(); LiveData<List<Playlist>> getAll(String serverId);
@Insert(onConflict = OnConflictStrategy.REPLACE) @Insert(onConflict = OnConflictStrategy.REPLACE)
void insert(Playlist playlist); void insert(Playlist playlist);

View file

@ -21,7 +21,7 @@ public interface QueueDao {
@Insert(onConflict = OnConflictStrategy.REPLACE) @Insert(onConflict = OnConflictStrategy.REPLACE)
void insertAll(List<Queue> songQueueObject); void insertAll(List<Queue> songQueueObject);
@Query("DELETE FROM queue WHERE queue.track_order = :position") @Query("DELETE FROM queue WHERE queue.track_order=:position")
void deleteByPosition(int position); void deleteByPosition(int position);
@Query("DELETE FROM queue") @Query("DELETE FROM queue")

View file

@ -34,6 +34,9 @@ public class Playlist implements Parcelable {
@ColumnInfo(name = "playlist_duration") @ColumnInfo(name = "playlist_duration")
private long duration; private long duration;
@ColumnInfo(name = "server")
private String server;
public Playlist(com.cappielloantonio.play.subsonic.models.Playlist playlist) { public Playlist(com.cappielloantonio.play.subsonic.models.Playlist playlist) {
this.id = playlist.getId(); this.id = playlist.getId();
this.name = playlist.getName(); this.name = playlist.getName();
@ -49,12 +52,13 @@ public class Playlist implements Parcelable {
this.name = name; this.name = name;
} }
public Playlist(@NonNull String id, String name, String primary, int songCount, long duration) { public Playlist(@NonNull String id, String name, String primary, int songCount, long duration, String server) {
this.id = id; this.id = id;
this.name = name; this.name = name;
this.primary = primary; this.primary = primary;
this.songCount = songCount; this.songCount = songCount;
this.duration = duration; this.duration = duration;
this.server = server;
} }
@NonNull @NonNull
@ -82,6 +86,14 @@ public class Playlist implements Parcelable {
return duration; return duration;
} }
public String getServer() {
return server;
}
public void setServer(String server) {
this.server = server;
}
@Override @Override
public boolean equals(Object o) { public boolean equals(Object o) {
if (this == o) return true; if (this == o) return true;

View file

@ -154,8 +154,8 @@ public class PlaylistRepository {
}); });
} }
public LiveData<List<Playlist>> getPinnedPlaylists() { public LiveData<List<Playlist>> getPinnedPlaylists(String serverId) {
return playlistDao.getAll(); return playlistDao.getAll(serverId);
} }
public void insert(Playlist playlist) { public void insert(Playlist playlist) {

View file

@ -8,6 +8,7 @@ import androidx.lifecycle.LifecycleOwner;
import androidx.lifecycle.LiveData; import androidx.lifecycle.LiveData;
import androidx.lifecycle.MutableLiveData; import androidx.lifecycle.MutableLiveData;
import com.cappielloantonio.play.App;
import com.cappielloantonio.play.model.Album; import com.cappielloantonio.play.model.Album;
import com.cappielloantonio.play.model.Artist; import com.cappielloantonio.play.model.Artist;
import com.cappielloantonio.play.model.Playlist; import com.cappielloantonio.play.model.Playlist;
@ -16,6 +17,7 @@ import com.cappielloantonio.play.repository.AlbumRepository;
import com.cappielloantonio.play.repository.ArtistRepository; import com.cappielloantonio.play.repository.ArtistRepository;
import com.cappielloantonio.play.repository.PlaylistRepository; import com.cappielloantonio.play.repository.PlaylistRepository;
import com.cappielloantonio.play.repository.SongRepository; import com.cappielloantonio.play.repository.SongRepository;
import com.cappielloantonio.play.util.PreferenceUtil;
import java.util.Collections; import java.util.Collections;
import java.util.List; import java.util.List;
@ -96,7 +98,7 @@ public class HomeViewModel extends AndroidViewModel {
} }
public LiveData<List<Playlist>> getPinnedPlaylistList(LifecycleOwner owner, int maxNumber, boolean random) { public LiveData<List<Playlist>> getPinnedPlaylistList(LifecycleOwner owner, int maxNumber, boolean random) {
playlistRepository.getPinnedPlaylists().observe(owner, playlists -> { playlistRepository.getPinnedPlaylists(PreferenceUtil.getInstance(App.getInstance()).getServerId()).observe(owner, playlists -> {
if (random) Collections.shuffle(playlists); if (random) Collections.shuffle(playlists);
List<Playlist> subPlaylist = playlists.subList(0, Math.min(maxNumber, playlists.size())); List<Playlist> subPlaylist = playlists.subList(0, Math.min(maxNumber, playlists.size()));
pinnedPlaylists.postValue(subPlaylist); pinnedPlaylists.postValue(subPlaylist);

View file

@ -8,10 +8,12 @@ import androidx.lifecycle.AndroidViewModel;
import androidx.lifecycle.LiveData; import androidx.lifecycle.LiveData;
import androidx.lifecycle.MutableLiveData; import androidx.lifecycle.MutableLiveData;
import com.cappielloantonio.play.App;
import com.cappielloantonio.play.model.Playlist; import com.cappielloantonio.play.model.Playlist;
import com.cappielloantonio.play.repository.DownloadRepository; import com.cappielloantonio.play.repository.DownloadRepository;
import com.cappielloantonio.play.repository.PlaylistRepository; import com.cappielloantonio.play.repository.PlaylistRepository;
import com.cappielloantonio.play.util.MappingUtil; import com.cappielloantonio.play.util.MappingUtil;
import com.cappielloantonio.play.util.PreferenceUtil;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List; import java.util.List;
@ -51,7 +53,7 @@ public class PlaylistCatalogueViewModel extends AndroidViewModel {
public LiveData<List<Playlist>> getPinnedPlaylistList(FragmentActivity activity) { public LiveData<List<Playlist>> getPinnedPlaylistList(FragmentActivity activity) {
pinnedPlaylistList = new MutableLiveData<>(new ArrayList<>()); pinnedPlaylistList = new MutableLiveData<>(new ArrayList<>());
playlistRepository.getPinnedPlaylists().observe(activity, playlists -> pinnedPlaylistList.postValue(playlists)); playlistRepository.getPinnedPlaylists(PreferenceUtil.getInstance(App.getInstance()).getServerId()).observe(activity, playlists -> pinnedPlaylistList.postValue(playlists));
return pinnedPlaylistList; return pinnedPlaylistList;
} }

View file

@ -8,11 +8,13 @@ import androidx.lifecycle.AndroidViewModel;
import androidx.lifecycle.LiveData; import androidx.lifecycle.LiveData;
import androidx.lifecycle.MutableLiveData; import androidx.lifecycle.MutableLiveData;
import com.cappielloantonio.play.App;
import com.cappielloantonio.play.model.Playlist; import com.cappielloantonio.play.model.Playlist;
import com.cappielloantonio.play.model.Song; import com.cappielloantonio.play.model.Song;
import com.cappielloantonio.play.repository.DownloadRepository; import com.cappielloantonio.play.repository.DownloadRepository;
import com.cappielloantonio.play.repository.PlaylistRepository; import com.cappielloantonio.play.repository.PlaylistRepository;
import com.cappielloantonio.play.util.MappingUtil; import com.cappielloantonio.play.util.MappingUtil;
import com.cappielloantonio.play.util.PreferenceUtil;
import java.util.List; import java.util.List;
@ -48,6 +50,7 @@ public class PlaylistPageViewModel extends AndroidViewModel {
public void setPlaylist(Playlist playlist) { public void setPlaylist(Playlist playlist) {
this.playlist = playlist; this.playlist = playlist;
this.playlist.setServer(PreferenceUtil.getInstance(App.getInstance()).getServerId());
} }
public void setOffline(boolean offline) { public void setOffline(boolean offline) {
@ -60,7 +63,7 @@ public class PlaylistPageViewModel extends AndroidViewModel {
public LiveData<Boolean> isPinned(FragmentActivity activity) { public LiveData<Boolean> isPinned(FragmentActivity activity) {
MutableLiveData<Boolean> isPinnedLive = new MutableLiveData<>(); MutableLiveData<Boolean> isPinnedLive = new MutableLiveData<>();
playlistRepository.getPinnedPlaylists().observe(activity, playlists -> isPinnedLive.postValue(playlists.contains(playlist))); playlistRepository.getPinnedPlaylists(PreferenceUtil.getInstance(App.getInstance()).getServerId()).observe(activity, playlists -> isPinnedLive.postValue(playlists.contains(playlist)));
return isPinnedLive; return isPinnedLive;
} }