gui/sidebar: Add sizes to Collection and History entries

Signed-off-by: Anna Schumaker <Anna@OcarinaProject.net>
This commit is contained in:
Anna Schumaker 2016-01-07 09:37:00 -05:00
parent eb137c4339
commit c663f287d4
4 changed files with 64 additions and 6 deletions

View File

@ -1,7 +1,10 @@
/*
* Copyright 2015 (c) Anna Schumaker.
*/
extern "C" {
#include <core/string.h>
#include <gui/sidebar.h>
}
#include <gui/queue/label.h>
@ -35,6 +38,7 @@ void CollectionLabel :: set_size()
{
gchar *size = g_strdup_printf("%u", queue_size(_queue));
collection_size->set_text(size);
gui_sidebar_set_size(_queue);
g_free(size);
}
@ -51,6 +55,7 @@ void HistoryLabel :: set_size()
{
gchar *size = g_strdup_printf("%u", queue_size(_queue));
history_size->set_text(size);
gui_sidebar_set_size(_queue);
g_free(size);
}

View File

@ -9,6 +9,9 @@
#include <gui/sidebar.h>
const gchar *SIDEBAR_SETTING = "gui.sidebar.pos";
const gchar *COLLECTION_FMT = "<big>Collection</big>\n%d track%s";
const gchar *HISTORY_FMT = "<big>History</big>\n%d track%s";
static GtkListStore *sb_store;
enum sidebar_columns {
@ -18,11 +21,42 @@ enum sidebar_columns {
SB_QUEUE,
};
void __sidebar_set_queue(GtkTreeIter *iter, struct queue *queue)
static void __sidebar_set_size(GtkTreeIter *iter, const gchar *name,
unsigned int size)
{
const gchar *fmt = "<big>%s</big>\n%d track%s";
gchar *text;
text = g_strdup_printf(fmt, name, size, (size == 1) ? "" : "s");
gtk_list_store_set(sb_store, iter, SB_TEXT, text, -1);
g_free(text);
}
static void __sidebar_set_queue(GtkTreeIter *iter, struct queue *queue)
{
gtk_list_store_set(sb_store, iter, SB_QUEUE, queue, -1);
}
static struct queue *__sidebar_get_queue(GtkTreeIter *iter)
{
struct queue *queue;
gtk_tree_model_get(GTK_TREE_MODEL(sb_store), iter, SB_QUEUE, &queue, -1);
return queue;
}
static bool __sidebar_find_queue(struct queue *queue, GtkTreeIter *iter)
{
gtk_tree_model_get_iter_first(GTK_TREE_MODEL(sb_store), iter);
do {
if (__sidebar_get_queue(iter) == queue)
return true;
} while (gtk_tree_model_iter_next(GTK_TREE_MODEL(sb_store), iter));
return false;
}
void __sidebar_resize(GtkPaned *pane, GParamSpec *pspec, gpointer data)
{
gui_settings_set(SIDEBAR_SETTING, gtk_paned_get_position(pane));
@ -89,3 +123,17 @@ void gui_sidebar_selected(enum sidebar_selection_t selected)
if (selected != SB_SIDEBAR)
__sidebar_deselect("o_sidebar_view");
}
void gui_sidebar_set_size(struct queue *queue)
{
const gchar *name = "Collection";
GtkTreeIter iter;
if (!__sidebar_find_queue(queue, &iter))
return;
if (queue == history_get_queue())
name = "History";
__sidebar_set_size(&iter, name, queue_size(queue));
}

View File

@ -4,6 +4,8 @@
#ifndef OCARINA_GUI_SIDEBAR_H
#define OCARINA_GUI_SIDEBAR_H
#include <gtk/gtk.h>
enum sidebar_selection_t {
SB_COLLECTION,
SB_PLAYLIST,
@ -20,4 +22,7 @@ gboolean gui_sidebar_on_select(GtkTreeSelection *, GtkTreeModel *,
/* Called to tell the sidebar that the selection has changed. */
void gui_sidebar_selected(enum sidebar_selection_t);
/* Called to set the size of sidebar entries. */
void gui_sidebar_set_size(struct queue *);
#endif /* OCARINA_GUI_SIDEBAR_H */

View File

@ -321,8 +321,8 @@
<property name="icon_name">media-skip-backward</property>
</object>
</child>
<accelerator key="AudioPrev" signal="clicked"/>
<accelerator key="n" signal="clicked" modifiers="GDK_SHIFT_MASK"/>
<accelerator key="AudioPrev" signal="clicked"/>
</object>
<packing>
<property name="expand">False</property>
@ -356,8 +356,8 @@
<property name="icon_size">5</property>
</object>
</child>
<accelerator key="AudioPlay" signal="clicked"/>
<accelerator key="space" signal="clicked"/>
<accelerator key="AudioPlay" signal="clicked"/>
</object>
<packing>
<property name="expand">False</property>
@ -390,8 +390,8 @@
<property name="icon_size">5</property>
</object>
</child>
<accelerator key="AudioPlay" signal="clicked"/>
<accelerator key="space" signal="clicked"/>
<accelerator key="AudioPlay" signal="clicked"/>
</object>
<packing>
<property name="expand">False</property>
@ -424,8 +424,8 @@
<property name="icon_name">media-playback-stop</property>
</object>
</child>
<accelerator key="space" signal="clicked" modifiers="GDK_MOD1_MASK"/>
<accelerator key="AudioPlay" signal="clicked" modifiers="GDK_MOD1_MASK"/>
<accelerator key="space" signal="clicked" modifiers="GDK_MOD1_MASK"/>
</object>
<packing>
<property name="expand">False</property>
@ -458,8 +458,8 @@
<property name="icon_name">media-skip-forward</property>
</object>
</child>
<accelerator key="AudioNext" signal="clicked"/>
<accelerator key="n" signal="clicked"/>
<accelerator key="AudioNext" signal="clicked"/>
</object>
<packing>
<property name="expand">False</property>