Merge pull request #13 from felipesere/develop

Implement basic playlist that simply queues songs
This commit is contained in:
Henrik
2019-03-04 18:03:05 +01:00
committed by GitHub
5 changed files with 64 additions and 0 deletions

View File

@@ -36,6 +36,7 @@ have them configurable.
* `F1`: Debug log
* `F2`: Queue
* `F3`: Search
* `F4`: Playlists, then hit `Return` to queue all songs from the playlist
* Tracks can be played using `Return` and queued using `Space`
* `Shift-p` toggles playback of a track
* `Shift-s` stops a track

View File

@@ -132,6 +132,10 @@ fn main() {
let search = ui::search::SearchView::new(spotify.clone(), queue.clone());
cursive.add_fullscreen_layer(search.view);
let playlistscreen = cursive.add_active_screen();
let playlists = ui::playlist::PlaylistView::new(queue.clone(), spotify.clone());
cursive.add_fullscreen_layer(playlists.view);
let queuescreen = cursive.add_active_screen();
let mut queueview = ui::queue::QueueView::new(queue.clone(), spotify.clone());
cursive.add_fullscreen_layer(queueview.view.take().unwrap());
@@ -157,6 +161,10 @@ fn main() {
s.set_screen(searchscreen);
});
cursive.add_global_callback(Key::F4, move |s| {
s.set_screen(playlistscreen);
});
// cursive event loop
while cursive.is_running() {
cursive.step();

View File

@@ -12,6 +12,8 @@ use librespot::playback::player::Player;
use rspotify::spotify::client::Spotify as SpotifyAPI;
use rspotify::spotify::model::search::SearchTracks;
use rspotify::spotify::model::playlist::{SimplifiedPlaylist, PlaylistTrack};
use rspotify::spotify::model::page::Page;
use failure::Error;
@@ -49,6 +51,7 @@ pub struct Spotify {
pub api: SpotifyAPI,
channel: mpsc::UnboundedSender<WorkerCommand>,
events: EventManager,
user: String,
}
struct Worker {
@@ -184,6 +187,7 @@ impl Spotify {
api: api,
channel: tx,
events: events,
user: user,
}
}
@@ -223,6 +227,14 @@ impl Spotify {
self.api.search_track(query, limit, offset, None)
}
pub fn current_user_playlist(&self, limit: u32, offset: u32) -> Result<Page<SimplifiedPlaylist>, Error> {
self.api.current_user_playlists(limit, offset)
}
pub fn user_playlist_tracks(&self, playlist_id: &str) -> Result<Page<PlaylistTrack>, Error> {
self.api.user_playlist_tracks(&self.user, playlist_id, None, 50, 0, None)
}
pub fn load(&self, track: SpotifyId) {
info!("loading track: {:?}", track);
self.channel

View File

@@ -1,3 +1,4 @@
pub mod queue;
pub mod search;
pub mod trackbutton;
pub mod playlist;

42
src/ui/playlist.rs Normal file
View File

@@ -0,0 +1,42 @@
use std::sync::{Arc, Mutex};
use cursive::direction::Orientation;
use cursive::traits::Boxable;
use cursive::views::*;
use spotify::Spotify;
use queue::Queue;
pub struct PlaylistView {
pub view: Panel<LinearLayout>,
}
impl PlaylistView {
pub fn new(queue: Arc<Mutex<Queue>>, spotify: Arc<Spotify>) -> PlaylistView {
let mut results = SelectView::new();
let playlists = spotify.current_user_playlist(50, 0).unwrap().items;
for playlist in &playlists {
results.add_item(playlist.name.clone(), playlist.id.clone());
}
let spotify_ref = spotify.clone();
results.set_on_submit(move |_s, id| {
let tracks = spotify_ref.user_playlist_tracks(id).unwrap().items;
let mut l_queue = queue.lock().expect("Could not aquire lock");
for playlist_track in tracks {
l_queue.enqueue(playlist_track.track.clone());
}
});
let scrollable = ScrollView::new(results).full_width().full_height();
let layout = LinearLayout::new(Orientation::Vertical).child(scrollable);
let rootpanel = Panel::new(layout).title("Playlists");
PlaylistView {
view: rootpanel,
}
}
}