package code.name.monkey.retromusic.db import androidx.lifecycle.LiveData import androidx.room.* @Dao interface PlaylistDao { @Insert suspend fun createPlaylist(playlistEntity: PlaylistEntity): Long @Query("UPDATE PlaylistEntity SET playlist_name = :name WHERE playlist_id = :playlistId") suspend fun renamePlaylist(playlistId: Int, name: String) @Query("SELECT * FROM PlaylistEntity WHERE playlist_name = :name") fun isPlaylistExists(name: String): List @Query("SELECT * FROM PlaylistEntity") suspend fun playlists(): List @Query("DELETE FROM SongEntity WHERE playlist_creator_id = :playlistId") suspend fun deleteSongsInPlaylist(playlistId: Int) @Query("DELETE FROM SongEntity WHERE playlist_creator_id = :playlistId AND id = :songId") suspend fun removeSongFromPlaylist(playlistId: Int, songId: Int) @Transaction @Query("SELECT * FROM PlaylistEntity") suspend fun playlistsWithSongs(): List @Insert(onConflict = OnConflictStrategy.REPLACE) suspend fun insertSongsToPlaylist(songEntities: List) @Query("SELECT * FROM SongEntity WHERE playlist_creator_id = :playlistId AND id = :songId") suspend fun isSongExistsInPlaylist(playlistId: Int, songId: Int): List @Query("SELECT * FROM SongEntity WHERE playlist_creator_id = :playlistId") suspend fun songsFromPlaylist(playlistId: Int): List @Delete suspend fun deletePlaylist(playlistEntity: PlaylistEntity) @Delete suspend fun deletePlaylists(playlistEntities: List) @Delete suspend fun deleteSongsInPlaylist(songs: List) @Insert(onConflict = OnConflictStrategy.REPLACE) suspend fun insertSongInHistory(historyEntity: HistoryEntity) @Query("SELECT * FROM HistoryEntity WHERE id = :songId LIMIT 1") suspend fun isSongPresentInHistory(songId: Int): HistoryEntity? @Update suspend fun updateHistorySong(historyEntity: HistoryEntity) @Query("SELECT * FROM HistoryEntity ORDER BY time_played DESC") fun historySongs(): LiveData> @Query("SELECT * FROM SongEntity WHERE playlist_creator_id= :playlistId") fun favoritesSongsLiveData(playlistId: Int): LiveData> @Query("SELECT * FROM SongEntity WHERE playlist_creator_id= :playlistId") fun favoritesSongs(playlistId: Int): List @Insert(onConflict = OnConflictStrategy.REPLACE) fun insertSongInPlayCount(playCountEntity: PlayCountEntity) @Update fun updateSongInPlayCount(playCountEntity: PlayCountEntity) @Delete fun deleteSongInPlayCount(playCountEntity: PlayCountEntity) @Query("SELECT * FROM PlayCountEntity WHERE id =:songId") fun checkSongExistInPlayCount(songId: Int): List @Query("SELECT * FROM PlayCountEntity ORDER BY play_count DESC") fun playCountSongs(): List @Insert(onConflict = OnConflictStrategy.REPLACE) fun insertBlacklistPath(blackListStoreEntity: BlackListStoreEntity) @Insert(onConflict = OnConflictStrategy.REPLACE) suspend fun insertBlacklistPath(blackListStoreEntities: List) @Delete suspend fun deleteBlacklistPath(blackListStoreEntity: BlackListStoreEntity) @Query("DELETE FROM BlackListStoreEntity") suspend fun clearBlacklist() }