Improve playlist page design

This commit is contained in:
Elias Projahn 2024-07-13 12:20:39 +02:00
parent b9c874ab8c
commit 09bedc892b
6 changed files with 56 additions and 37 deletions

View file

@ -219,12 +219,6 @@ impl MusicusPlayer {
return;
}
let title = format!(
"{}: {}",
recording.work.composers_string(),
recording.work.name.get(),
);
let performances = recording.performers_string();
let mut items = Vec::new();
@ -232,7 +226,8 @@ impl MusicusPlayer {
if tracks.len() == 1 {
items.push(PlaylistItem::new(
true,
&title,
Some(&recording.work.composers_string()),
&recording.work.name.get(),
Some(&performances),
None,
&tracks[0].path,
@ -259,7 +254,8 @@ impl MusicusPlayer {
items.push(PlaylistItem::new(
true,
&title,
Some(&recording.work.composers_string()),
&recording.work.name.get(),
Some(&performances),
Some(&track_title(&first_track, 1)),
&first_track.path,
@ -269,7 +265,8 @@ impl MusicusPlayer {
for (index, track) in tracks.enumerate() {
items.push(PlaylistItem::new(
false,
&title,
Some(&recording.work.composers_string()),
&recording.work.name.get(),
Some(&performances),
// track number = track index + 1 (first track) + 1 (zero based)
Some(&track_title(&track, index + 2)),

View file

@ -17,7 +17,10 @@ mod imp {
pub is_title: OnceCell<bool>,
#[property(get, construct_only)]
pub title: OnceCell<String>,
pub composers: OnceCell<Option<String>>,
#[property(get, construct_only)]
pub work: OnceCell<String>,
#[property(get, construct_only, nullable)]
pub performers: OnceCell<Option<String>>,
@ -49,7 +52,8 @@ glib::wrapper! {
impl PlaylistItem {
pub fn new(
is_title: bool,
title: &str,
composers: Option<&str>,
work: &str,
performers: Option<&str>,
part_title: Option<&str>,
path: impl AsRef<Path>,
@ -57,7 +61,8 @@ impl PlaylistItem {
) -> Self {
glib::Object::builder()
.property("is-title", is_title)
.property("title", title)
.property("composers", composers)
.property("work", work)
.property("performers", performers)
.property("part-title", part_title)
.property("path", path.as_ref())
@ -66,7 +71,14 @@ impl PlaylistItem {
}
pub fn make_title(&self) -> String {
let mut title = self.title();
let mut title = String::new();
if let Some(composers) = self.composers() {
title.push_str(&composers);
title.push_str(": ");
}
title.push_str(&self.work());
if let Some(part_title) = self.part_title() {
title.push_str(": ");

View file

@ -11,7 +11,9 @@ mod imp {
#[template_child]
pub playing_icon: TemplateChild<gtk::Image>,
#[template_child]
pub title_label: TemplateChild<gtk::Label>,
pub composers_label: TemplateChild<gtk::Label>,
#[template_child]
pub work_label: TemplateChild<gtk::Label>,
#[template_child]
pub performances_label: TemplateChild<gtk::Label>,
#[template_child]
@ -59,12 +61,19 @@ impl PlaylistTile {
if let Some(item) = item {
if item.is_title() {
imp.title_label.set_label(&item.title());
imp.title_label.set_visible(true);
if let Some(composers) = item.composers() {
imp.composers_label.set_label(&composers);
imp.composers_label.set_visible(true);
imp.work_label.set_margin_top(3);
}
imp.work_label.set_label(&item.work());
imp.work_label.set_visible(true);
if let Some(performances) = item.performers() {
imp.performances_label.set_label(&performances);
imp.performances_label.set_visible(true);
imp.work_label.set_margin_bottom(6);
}
}