mirror of
https://github.com/transmission/transmission.git
synced 2025-12-23 11:58:36 +00:00
(gtk) yin/yang icon: add a pulldown menu for {total,session}{ratio,transfer}
This commit is contained in:
@@ -748,7 +748,6 @@ setpex( tr_torrent * tor, void * arg )
|
|||||||
gboolean
|
gboolean
|
||||||
updatemodel(gpointer gdata) {
|
updatemodel(gpointer gdata) {
|
||||||
struct cbdata *data = gdata;
|
struct cbdata *data = gdata;
|
||||||
float up, down;
|
|
||||||
|
|
||||||
if( !data->closing && 0 < global_sigcount )
|
if( !data->closing && 0 < global_sigcount )
|
||||||
{
|
{
|
||||||
@@ -760,11 +759,8 @@ updatemodel(gpointer gdata) {
|
|||||||
tr_core_update( data->core );
|
tr_core_update( data->core );
|
||||||
|
|
||||||
/* update the main window's statusbar and toolbar buttons */
|
/* update the main window's statusbar and toolbar buttons */
|
||||||
if( NULL != data->wind )
|
if( data->wind )
|
||||||
{
|
tr_window_update( data->wind );
|
||||||
tr_torrentRates( tr_core_handle( data->core ), &down, &up );
|
|
||||||
tr_window_update( data->wind, down, up );
|
|
||||||
}
|
|
||||||
|
|
||||||
/* update the message window */
|
/* update the message window */
|
||||||
msgwin_update();
|
msgwin_update();
|
||||||
|
|||||||
@@ -29,6 +29,7 @@ tr_prefs_init_global( void )
|
|||||||
{
|
{
|
||||||
cf_check_older_configs( );
|
cf_check_older_configs( );
|
||||||
|
|
||||||
|
pref_string_set_default ( PREF_KEY_STATUS_BAR_STATS, "total-ratio" );
|
||||||
pref_flag_set_default ( PREF_KEY_STATUS_BAR, TRUE );
|
pref_flag_set_default ( PREF_KEY_STATUS_BAR, TRUE );
|
||||||
pref_flag_set_default ( PREF_KEY_TOOLBAR, TRUE );
|
pref_flag_set_default ( PREF_KEY_TOOLBAR, TRUE );
|
||||||
|
|
||||||
|
|||||||
@@ -39,6 +39,7 @@ GtkWidget * tr_prefs_dialog_new( GObject * core, GtkWindow * parent );
|
|||||||
#define PREF_KEY_SORT_REVERSED "sort-reversed"
|
#define PREF_KEY_SORT_REVERSED "sort-reversed"
|
||||||
#define PREF_KEY_MINIMAL_VIEW "minimal-view"
|
#define PREF_KEY_MINIMAL_VIEW "minimal-view"
|
||||||
#define PREF_KEY_STATUS_BAR "show-status-bar"
|
#define PREF_KEY_STATUS_BAR "show-status-bar"
|
||||||
|
#define PREF_KEY_STATUS_BAR_STATS "status-bar-stats"
|
||||||
#define PREF_KEY_TOOLBAR "show-toolbar"
|
#define PREF_KEY_TOOLBAR "show-toolbar"
|
||||||
|
|
||||||
void tr_prefs_init_global( void );
|
void tr_prefs_init_global( void );
|
||||||
|
|||||||
@@ -54,6 +54,7 @@ typedef struct
|
|||||||
GtkWidget * view;
|
GtkWidget * view;
|
||||||
GtkWidget * toolbar;
|
GtkWidget * toolbar;
|
||||||
GtkWidget * status;
|
GtkWidget * status;
|
||||||
|
GtkWidget * status_menu;
|
||||||
GtkWidget * ul_lb;
|
GtkWidget * ul_lb;
|
||||||
GtkWidget * dl_lb;
|
GtkWidget * dl_lb;
|
||||||
GtkWidget * stats_lb;
|
GtkWidget * stats_lb;
|
||||||
@@ -163,6 +164,10 @@ prefsChanged( TrCore * core UNUSED, const char * key, gpointer wind )
|
|||||||
const gboolean isEnabled = pref_flag_get( key );
|
const gboolean isEnabled = pref_flag_get( key );
|
||||||
g_object_set( p->toolbar, "visible", isEnabled, NULL );
|
g_object_set( p->toolbar, "visible", isEnabled, NULL );
|
||||||
}
|
}
|
||||||
|
else if( !strcmp( key, PREF_KEY_STATUS_BAR_STATS ) )
|
||||||
|
{
|
||||||
|
tr_window_update( (TrWindow*)wind );
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
@@ -173,6 +178,36 @@ privateFree( gpointer vprivate )
|
|||||||
g_free( p );
|
g_free( p );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
onYinYangReleased( GtkWidget * w UNUSED, GdkEventButton * button UNUSED, gpointer vprivate )
|
||||||
|
{
|
||||||
|
PrivateData * p = ( PrivateData * ) vprivate;
|
||||||
|
gtk_menu_popup( GTK_MENU( p->status_menu ), 0, 0, 0, 0, 0, gtk_get_current_event_time( ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
#define STATS_MODE "stats-mode"
|
||||||
|
|
||||||
|
static struct {
|
||||||
|
const char *val, *i18n;
|
||||||
|
} stats_modes[] = {
|
||||||
|
{ "total-ratio", N_("Total Ratio") },
|
||||||
|
{ "session-ratio", N_("Session Ratio") },
|
||||||
|
{ "total-transfer", N_("Total Transfer") },
|
||||||
|
{ "session-transfer", N_("Session Transfer") }
|
||||||
|
};
|
||||||
|
|
||||||
|
static void
|
||||||
|
status_menu_toggled_cb( GtkCheckMenuItem * menu_item,
|
||||||
|
gpointer vprivate )
|
||||||
|
{
|
||||||
|
if( gtk_check_menu_item_get_active( menu_item ) )
|
||||||
|
{
|
||||||
|
PrivateData * p = (PrivateData*) vprivate;
|
||||||
|
const char * val = g_object_get_data( G_OBJECT( menu_item ), STATS_MODE );
|
||||||
|
tr_core_set_pref( p->core, PREF_KEY_STATUS_BAR_STATS, val );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/***
|
/***
|
||||||
**** PUBLIC
|
**** PUBLIC
|
||||||
***/
|
***/
|
||||||
@@ -180,8 +215,11 @@ privateFree( gpointer vprivate )
|
|||||||
GtkWidget *
|
GtkWidget *
|
||||||
tr_window_new( GtkUIManager * ui_manager, TrCore * core )
|
tr_window_new( GtkUIManager * ui_manager, TrCore * core )
|
||||||
{
|
{
|
||||||
|
int i, n;
|
||||||
|
int status_stats_mode;
|
||||||
|
char * pch;
|
||||||
PrivateData * p = g_new( PrivateData, 1 );
|
PrivateData * p = g_new( PrivateData, 1 );
|
||||||
GtkWidget *vbox, *w, *self, *h;
|
GtkWidget *vbox, *w, *self, *h, *c;
|
||||||
|
|
||||||
/* make the window */
|
/* make the window */
|
||||||
self = gtk_window_new (GTK_WINDOW_TOPLEVEL);
|
self = gtk_window_new (GTK_WINDOW_TOPLEVEL);
|
||||||
@@ -204,6 +242,24 @@ tr_window_new( GtkUIManager * ui_manager, TrCore * core )
|
|||||||
w = p->toolbar = action_get_widget( "/main-window-toolbar" );
|
w = p->toolbar = action_get_widget( "/main-window-toolbar" );
|
||||||
gtk_box_pack_start( GTK_BOX(vbox), w, FALSE, FALSE, 0 );
|
gtk_box_pack_start( GTK_BOX(vbox), w, FALSE, FALSE, 0 );
|
||||||
|
|
||||||
|
/* status menu */
|
||||||
|
GtkWidget * menu = p->status_menu = gtk_menu_new( );
|
||||||
|
status_stats_mode = 0;
|
||||||
|
GSList * l = NULL;
|
||||||
|
pch = pref_string_get( PREF_KEY_STATUS_BAR_STATS );
|
||||||
|
for( i=0, n=G_N_ELEMENTS(stats_modes); i<n; ++i )
|
||||||
|
{
|
||||||
|
const char * val = stats_modes[i].val;
|
||||||
|
w = gtk_radio_menu_item_new_with_label( l, _( stats_modes[i].i18n ) );
|
||||||
|
l = gtk_radio_menu_item_get_group( GTK_RADIO_MENU_ITEM(w) );
|
||||||
|
gtk_check_menu_item_set_active( GTK_CHECK_MENU_ITEM(w), !strcmp( val, pch ) );
|
||||||
|
g_object_set_data( G_OBJECT(w), STATS_MODE, (gpointer)stats_modes[i].val );
|
||||||
|
g_signal_connect( w, "toggled", G_CALLBACK(status_menu_toggled_cb), p );
|
||||||
|
gtk_menu_shell_append( GTK_MENU_SHELL(menu), w );
|
||||||
|
gtk_widget_show( w );
|
||||||
|
}
|
||||||
|
g_free( pch );
|
||||||
|
|
||||||
/* statusbar */
|
/* statusbar */
|
||||||
h = p->status = gtk_hbox_new( FALSE, GUI_PAD );
|
h = p->status = gtk_hbox_new( FALSE, GUI_PAD );
|
||||||
gtk_container_set_border_width( GTK_CONTAINER(h), GUI_PAD );
|
gtk_container_set_border_width( GTK_CONTAINER(h), GUI_PAD );
|
||||||
@@ -221,6 +277,10 @@ tr_window_new( GtkUIManager * ui_manager, TrCore * core )
|
|||||||
gtk_box_pack_end( GTK_BOX(h), w, FALSE, FALSE, 0 );
|
gtk_box_pack_end( GTK_BOX(h), w, FALSE, FALSE, 0 );
|
||||||
|
|
||||||
w = gtk_image_new_from_stock( "tr-yin-yang", (GtkIconSize)-1 );
|
w = gtk_image_new_from_stock( "tr-yin-yang", (GtkIconSize)-1 );
|
||||||
|
c = gtk_event_box_new( );
|
||||||
|
gtk_container_add( GTK_CONTAINER(c), w );
|
||||||
|
w = c;
|
||||||
|
g_signal_connect( w, "button-release-event", G_CALLBACK(onYinYangReleased), p );
|
||||||
gtk_box_pack_start( GTK_BOX(h), w, FALSE, FALSE, 0 );
|
gtk_box_pack_start( GTK_BOX(h), w, FALSE, FALSE, 0 );
|
||||||
w = p->stats_lb = gtk_label_new( NULL );
|
w = p->stats_lb = gtk_label_new( NULL );
|
||||||
gtk_box_pack_start( GTK_BOX(h), w, FALSE, FALSE, 0 );
|
gtk_box_pack_start( GTK_BOX(h), w, FALSE, FALSE, 0 );
|
||||||
@@ -245,6 +305,7 @@ tr_window_new( GtkUIManager * ui_manager, TrCore * core )
|
|||||||
/* listen for prefs changes that affect the window */
|
/* listen for prefs changes that affect the window */
|
||||||
prefsChanged( core, PREF_KEY_MINIMAL_VIEW, self );
|
prefsChanged( core, PREF_KEY_MINIMAL_VIEW, self );
|
||||||
prefsChanged( core, PREF_KEY_STATUS_BAR, self );
|
prefsChanged( core, PREF_KEY_STATUS_BAR, self );
|
||||||
|
prefsChanged( core, PREF_KEY_STATUS_BAR_STATS, self );
|
||||||
prefsChanged( core, PREF_KEY_TOOLBAR, self );
|
prefsChanged( core, PREF_KEY_TOOLBAR, self );
|
||||||
p->core = core;
|
p->core = core;
|
||||||
p->pref_handler_id = g_signal_connect( core, "prefs-changed",
|
p->pref_handler_id = g_signal_connect( core, "prefs-changed",
|
||||||
@@ -254,25 +315,49 @@ tr_window_new( GtkUIManager * ui_manager, TrCore * core )
|
|||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
tr_window_update( TrWindow * self, float downspeed, float upspeed )
|
tr_window_update( TrWindow * self )
|
||||||
{
|
{
|
||||||
PrivateData * p = get_private_data( self );
|
PrivateData * p = get_private_data( self );
|
||||||
|
tr_handle * handle = NULL;
|
||||||
|
|
||||||
|
if( p && p->core )
|
||||||
|
handle = tr_core_handle( p->core );
|
||||||
|
|
||||||
|
if( handle )
|
||||||
|
{
|
||||||
|
char * pch;
|
||||||
|
float u, d;
|
||||||
char up[32], down[32], buf[64];
|
char up[32], down[32], buf[64];
|
||||||
struct tr_session_stats stats;
|
struct tr_session_stats stats;
|
||||||
tr_handle * handle = tr_core_handle( p->core );
|
|
||||||
|
|
||||||
tr_strlspeed( buf, downspeed, sizeof( buf ) );
|
tr_torrentRates( handle, &d, &u );
|
||||||
|
tr_strlspeed( buf, d, sizeof( buf ) );
|
||||||
gtk_label_set_text( GTK_LABEL( p->dl_lb ), buf );
|
gtk_label_set_text( GTK_LABEL( p->dl_lb ), buf );
|
||||||
|
tr_strlspeed( buf, u, sizeof( buf ) );
|
||||||
tr_strlspeed( buf, upspeed, sizeof( buf ) );
|
|
||||||
gtk_label_set_text( GTK_LABEL( p->ul_lb ), buf );
|
gtk_label_set_text( GTK_LABEL( p->ul_lb ), buf );
|
||||||
|
|
||||||
|
pch = pref_string_get( PREF_KEY_STATUS_BAR_STATS );
|
||||||
|
if( !strcmp( pch, "session-ratio" ) ) {
|
||||||
|
tr_getSessionStats( handle, &stats );
|
||||||
|
g_snprintf( buf, sizeof(buf), _("Ratio: %.1f"), stats.ratio );
|
||||||
|
} else if( !strcmp( pch, "session-transfer" ) ) {
|
||||||
|
tr_getSessionStats( handle, &stats );
|
||||||
|
tr_strlsize( up, stats.uploadedBytes, sizeof( up ) );
|
||||||
|
tr_strlsize( down, stats.downloadedBytes, sizeof( down ) );
|
||||||
|
g_snprintf( buf, sizeof( buf ), _( "Down: %s Up: %s" ), down, up );
|
||||||
|
} else if( !strcmp( pch, "total-transfer" ) ) {
|
||||||
tr_getCumulativeSessionStats( handle, &stats );
|
tr_getCumulativeSessionStats( handle, &stats );
|
||||||
tr_strlsize( up, stats.uploadedBytes, sizeof( up ) );
|
tr_strlsize( up, stats.uploadedBytes, sizeof( up ) );
|
||||||
tr_strlsize( down, stats.downloadedBytes, sizeof( down ) );
|
tr_strlsize( down, stats.downloadedBytes, sizeof( down ) );
|
||||||
g_snprintf( buf, sizeof( buf ), _( "Down: %s Up: %s" ), down, up );
|
g_snprintf( buf, sizeof( buf ), _( "Down: %s Up: %s" ), down, up );
|
||||||
|
} else { /* default is total-ratio */
|
||||||
|
tr_getCumulativeSessionStats( handle, &stats );
|
||||||
|
g_snprintf( buf, sizeof(buf), _("Ratio: %.1f"), stats.ratio );
|
||||||
|
}
|
||||||
|
g_free( pch );
|
||||||
gtk_label_set_text( GTK_LABEL( p->stats_lb ), buf );
|
gtk_label_set_text( GTK_LABEL( p->stats_lb ), buf );
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
GtkTreeSelection*
|
GtkTreeSelection*
|
||||||
tr_window_get_selection ( TrWindow * w )
|
tr_window_get_selection ( TrWindow * w )
|
||||||
|
|||||||
@@ -34,6 +34,6 @@ GtkTreeSelection * tr_window_get_selection( TrWindow* wind );
|
|||||||
|
|
||||||
GtkWidget * tr_window_new( GtkUIManager*, TrCore * core );
|
GtkWidget * tr_window_new( GtkUIManager*, TrCore * core );
|
||||||
|
|
||||||
void tr_window_update( TrWindow * wind, float downspeed, float upspeed );
|
void tr_window_update( TrWindow * wind );
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|||||||
Reference in New Issue
Block a user