Move player bar to separate widget

This commit is contained in:
Elias Projahn 2023-10-27 12:32:40 +02:00
parent f16a27e343
commit 232faa6a2f
8 changed files with 261 additions and 141 deletions

90
data/ui/player_bar.blp Normal file
View file

@ -0,0 +1,90 @@
using Gtk 4.0;
using Adw 1;
template $MusicusPlayerBar : Gtk.Box {
styles ["playerbar"]
orientation: vertical;
margin-start: 6;
margin-end: 6;
margin-top: 12;
margin-bottom: 12;
spacing: 6;
Gtk.Box {
spacing: 6;
Gtk.Box {
valign: center;
hexpand: true;
margin-start: 10;
orientation: vertical;
Gtk.Label title_label {
styles ["title"]
halign: start;
label: _("Title");
ellipsize: end;
}
Gtk.Label subtitle_label {
styles ["subtitle", "dim-label"]
halign: start;
label: _("Subtitle");
ellipsize: end;
}
}
Gtk.Button back_button {
styles ["circular", "flat"]
valign: center;
icon-name: "media-skip-backward-symbolic";
}
Gtk.ToggleButton playlist_button {
styles ["flat", "circular"]
valign: center;
icon-name: "playlist-symbolic";
clicked => $show_playlist() swapped;
}
Gtk.Button forward_button {
styles ["circular", "flat"]
valign: center;
icon-name: "media-skip-forward-symbolic";
}
}
Gtk.Box {
spacing: 6;
Gtk.Button play_button {
styles ["circular", "flat"]
valign: center;
icon-name: "media-playback-start-symbolic";
clicked => $play_pause() swapped;
}
Gtk.Label current_time_label {
styles ["caption", "numeric"]
valign: center;
label: "00:00";
}
Gtk.Scale slider {
valign: center;
hexpand: true;
adjustment: Gtk.Adjustment {
lower: 0;
upper: 1;
value: 0.2;
step-increment: 0.01;
};
}
Gtk.Label remaining_time_label {
styles ["caption", "numeric"]
valign: center;
label: "01:00";
}
}
}

View file

@ -22,93 +22,6 @@ template $MusicusWindow : Adw.ApplicationWindow {
Gtk.Revealer player_bar_revealer {
reveal-child: true;
transition-type: slide_up;
Gtk.Box {
styles ["playerbar"]
orientation: vertical;
margin-start: 6;
margin-end: 6;
margin-top: 12;
margin-bottom: 12;
spacing: 6;
Gtk.Box {
spacing: 6;
Gtk.Box {
valign: center;
hexpand: true;
margin-start: 10;
orientation: vertical;
Gtk.Label title_label {
styles ["title"]
halign: start;
label: _("Title");
ellipsize: end;
}
Gtk.Label subtitle_label {
styles ["subtitle", "dim-label"]
halign: start;
label: _("Subtitle");
ellipsize: end;
}
}
Gtk.Button back_button {
styles ["circular", "flat"]
valign: center;
icon-name: "media-skip-backward-symbolic";
}
Gtk.ToggleButton playlist_button {
styles ["flat", "circular"]
valign: center;
icon-name: "playlist-symbolic";
toggled => $show_playlist() swapped;
}
Gtk.Button forward_button {
styles ["circular", "flat"]
valign: center;
icon-name: "media-skip-forward-symbolic";
}
}
Gtk.Box {
spacing: 6;
Gtk.Button play_button {
styles ["circular", "flat"]
valign: center;
icon-name: "media-playback-start-symbolic";
}
Gtk.Label current_time_label {
styles ["caption", "numeric"]
valign: center;
label: "00:00";
}
Gtk.Scale slider {
valign: center;
hexpand: true;
adjustment: Gtk.Adjustment {
lower: 0;
upper: 1;
value: 0.2;
step-increment: 0.01;
};
}
Gtk.Label remaining_time_label {
styles ["caption", "numeric"]
valign: center;
label: "01:00";
}
}
}
}
}
}