80 lines
2.9 KiB
Kotlin
80 lines
2.9 KiB
Kotlin
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 renamePlaylistEntity(playlistId: Int, name: String)
|
|
|
|
@Query("SELECT * FROM PlaylistEntity WHERE playlist_name = :name")
|
|
fun checkPlaylistExists(name: String): List<PlaylistEntity>
|
|
|
|
@Query("SELECT * FROM PlaylistEntity")
|
|
suspend fun playlists(): List<PlaylistEntity>
|
|
|
|
@Query("DELETE FROM SongEntity WHERE playlist_creator_id = :playlistId")
|
|
suspend fun deleteSongsInPlaylist(playlistId: Int)
|
|
|
|
@Transaction
|
|
@Query("SELECT * FROM PlaylistEntity")
|
|
suspend fun playlistsWithSong(): List<PlaylistWithSongs>
|
|
|
|
@Insert(onConflict = OnConflictStrategy.REPLACE)
|
|
suspend fun insertSongs(songEntities: List<SongEntity>)
|
|
|
|
@Query("SELECT * FROM SongEntity WHERE playlist_creator_id = :playlistId AND id = :songId")
|
|
suspend fun checkSongExistsWithPlaylistId(playlistId: Int, songId: Int): List<SongEntity>
|
|
|
|
@Query("SELECT * FROM SongEntity WHERE playlist_creator_id = :playlistId")
|
|
suspend fun getSongs(playlistId: Int): List<SongEntity>
|
|
|
|
@Query("DELETE FROM SongEntity WHERE playlist_creator_id = :playlistId AND id = :songId")
|
|
fun removeSong(playlistId: Int, songId: Int)
|
|
|
|
@Delete
|
|
suspend fun deletePlaylistEntity(playlistEntity: PlaylistEntity)
|
|
|
|
@Delete
|
|
suspend fun deletePlaylistEntities(playlistEntities: List<PlaylistEntity>)
|
|
|
|
@Delete
|
|
suspend fun deleteSongsInPlaylist(songs: List<SongEntity>)
|
|
|
|
@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<List<HistoryEntity>>
|
|
|
|
@Query("SELECT * FROM SongEntity WHERE playlist_creator_id= :playlistId")
|
|
fun favoritesSongsLiveData(playlistId: Int): LiveData<List<SongEntity>>
|
|
|
|
@Query("SELECT * FROM SongEntity WHERE playlist_creator_id= :playlistId")
|
|
fun favoritesSongs(playlistId: Int): List<SongEntity>
|
|
|
|
@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<PlayCountEntity>
|
|
|
|
@Query("SELECT * FROM PlayCountEntity ORDER BY play_count DESC")
|
|
fun playCountSongs(): List<PlayCountEntity>
|
|
} |