Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Queue widget rebase #572

Open
wants to merge 59 commits into
base: main
Choose a base branch
from
Open
Changes from 1 commit
Commits
Show all changes
59 commits
Select commit Hold shift + click to select a range
2295cef
Add ability to add to queue
May 7, 2024
856a70a
add ability to take queued song to other playlists, TODO: make it so …
May 10, 2024
7f0bab4
Add to queue rework - Now queues are held
May 12, 2024
ecd8546
Fix if switching contexts e.g: playing a different song from a differ…
May 31, 2024
9a99249
Change added_items to user_added_items, Lint using clippy.
Jun 16, 2024
8f13fdd
Linting done with format
Jun 16, 2024
bc9791f
Var name to user_items
Jun 16, 2024
a00272b
Remove redundant comment
Jun 16, 2024
4f5296a
UI change starting
Jun 19, 2024
6f27d9b
Merge branch 'master' of https://github.com/SO9010/psst
Jun 19, 2024
456a319
Queue view added (INCOMPLETE)
Jun 30, 2024
2ffb38a
Clear up
Jun 30, 2024
1b0d7c5
Remove from quieue buttom
Jun 30, 2024
b6fb954
Clean up and consistency...
jacksongoode Jul 2, 2024
67a7536
Center queue
jacksongoode Jul 2, 2024
ecb5256
Merge remote-tracking branch 'upstream/master'
Jul 12, 2024
abbc357
Align dividers
Jul 12, 2024
b67267d
Add left and right dividers
Jul 12, 2024
98f1824
Dynamically resize left side bar
Jul 14, 2024
d56ffcc
Allow long titles to break
jacksongoode Jul 14, 2024
6a1bf9f
Fix constraint causing issues
Jul 18, 2024
81f23cd
Merge branch 'master' of https://github.com/SO9010/psst
Jul 18, 2024
a60f52b
Improved widget switching
Jul 20, 2024
81d6ba0
More function, but it needs improvment.
Jul 20, 2024
e58b263
Fix overlap, this also makes the change in size smoother
Jul 21, 2024
5f59715
Hide queue if there are no items.
Jul 21, 2024
faf93b7
Lint
Jul 21, 2024
1c1e7bd
aha oops wrong way round
Jul 21, 2024
e9100c5
Info alert added
Jul 21, 2024
e976452
Remove by index
Jul 24, 2024
708c14f
Improved skipping method
Jul 25, 2024
57bd9c5
Add option to settings
Jul 25, 2024
f383da8
Clear queue
Jul 25, 2024
b9977aa
Fix oopsie and introduce context menu
Jul 25, 2024
40d1b6d
Merge branch 'jpochyla:master' into master
SO9010 Jul 25, 2024
8c3b1ae
Merge branch 'jpochyla:master' into master
SO9010 Jul 29, 2024
ceb9caa
Context menu update
Jul 29, 2024
9a62df4
Lint
Jul 29, 2024
17e60ba
Linting
jacksongoode Jul 30, 2024
c091fa1
Merge branch 'jpochyla:master' into master
SO9010 Aug 7, 2024
13215a7
Remove first song, need to clear some bugs now with removing from queue.
Aug 7, 2024
b308119
Fix remove from queue
Aug 7, 2024
5137a34
Fix skip to place in queue
Aug 7, 2024
13d4567
Lint
Aug 7, 2024
6e0e748
Fix queue repeats
Aug 9, 2024
3f48cbf
Merge branch 'jpochyla:master' into master
SO9010 Aug 24, 2024
2c4acfe
Fix dodgy playing
Aug 24, 2024
6ab7708
Linty
Aug 24, 2024
b42c7c9
Fix mistake
Aug 24, 2024
6f2d9b5
start to fix problems
Aug 26, 2024
cddcee0
start making it play if theres nothing there
Aug 27, 2024
ba9cbdb
Play even when no playlist is playing
Aug 27, 2024
ed3702e
Improvement
Aug 28, 2024
4e35a6c
Merge branch 'jpochyla:master' into master
SO9010 Sep 3, 2024
c7128f1
Lint!
Sep 19, 2024
9c61420
Merge branch 'jpochyla:master' into master
SO9010 Sep 23, 2024
f69b626
Merge branch 'jpochyla:master' into master
SO9010 Sep 26, 2024
5bf8a69
neaten appstate
Sep 26, 2024
0c1b45d
Fix
Dec 20, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Add to queue rework - Now queues are held
SO9010 authored and SO9010 committed May 12, 2024

Verified

This commit was created on GitHub.com and signed with GitHub’s verified signature.
commit 7f0bab48f0a082aa3f1407b856cbc76011beba85
2 changes: 1 addition & 1 deletion psst-gui/src/cmd.rs
Original file line number Diff line number Diff line change
@@ -4,7 +4,7 @@ use druid::{Selector, WidgetId};
use psst_core::{item_id::ItemId, player::item::PlaybackItem};

use crate::{
data::{Nav, PlaybackPayload, PlaylistTracks, QueueBehavior, QueueEntry},
data::{Nav, PlaybackPayload, QueueBehavior, QueueEntry},
ui::find::Find,
};

11 changes: 2 additions & 9 deletions psst-gui/src/controller/playback.rs
Original file line number Diff line number Diff line change
@@ -348,12 +348,7 @@ fn event(
data.start_playback(queued.item, queued.origin, progress.to_owned());
self.update_media_control_playback(&data.playback);
self.update_media_control_metadata(&data.playback);
} else if let Some(queued) = data.queued_entry(*item) {
data.start_playback(queued.item, queued.origin, progress.to_owned());
self.update_media_control_playback(&data.playback);
self.update_media_control_metadata(&data.playback);
}

else {
log::warn!("played item not found in playback queue");
}
@@ -421,11 +416,9 @@ fn event(
Event::Command(cmd) if cmd.is(cmd::ADD_TO_QUEUE) => {
log::info!("adding to queue");
let (entry, item) = cmd.get_unchecked(cmd::ADD_TO_QUEUE);

self.add_to_queue(&item.to_owned());
data.playback.added_queue.push_back(QueueEntry {
item: entry.item.to_owned(),
origin: entry.origin.to_owned(),
});
data.add_queued_entry(entry.clone());
ctx.set_handled();
}
Event::Command(cmd) if cmd.is(cmd::PLAY_QUEUE_BEHAVIOR) => {
26 changes: 13 additions & 13 deletions psst-gui/src/data/mod.rs
Original file line number Diff line number Diff line change
@@ -181,19 +181,19 @@ impl AppState {

impl AppState {
pub fn queued_entry(&self, item_id: ItemId) -> Option<QueueEntry> {
self.playback
.queue
.iter()
.find(|queued| queued.item.id() == item_id)
.cloned()
}

pub fn added_queued_entry(&self, item_id: ItemId) -> Option<QueueEntry> {
self.playback
.queue
.iter()
.find(|queued| queued.item.id() == item_id)
.cloned()
if let Some(queued) = self.playback.queue.iter().find(|queued| queued.item.id() == item_id).cloned() {
return Some(queued);
} else if let Some(queued) = self.playback.added_queue.iter().find(|queued| queued.item.id() == item_id).cloned() {
return Some(queued);
} else {
None
}
}

pub fn add_queued_entry(&mut self, queue_entry: QueueEntry) {
// it still gets updated and wiped when playlsit changes
self.playback.added_queue.push_back(queue_entry);

}

pub fn loading_playback(&mut self, item: Playable, origin: PlaybackOrigin) {
2 changes: 1 addition & 1 deletion psst-gui/src/ui/track.rs
Original file line number Diff line number Diff line change
@@ -9,7 +9,7 @@ use psst_core::{audio::normalize::NormalizationLevel, item_id::{ItemId, ItemIdTy
use crate::{
cmd,
data::{
self, AppState, Library, Nav, PlaybackOrigin, PlaylistAddTrack, PlaylistRemoveTrack, QueueEntry, RecommendationsRequest, Track
AppState, Library, Nav, PlaybackOrigin, PlaylistAddTrack, PlaylistRemoveTrack, QueueEntry, RecommendationsRequest, Track
},
ui::playlist,
widget::{icons, Empty, MyWidgetExt, RemoteImage},