#include <gtk/gtk.h>
#include <libappindicator/app-indicator.h>
+#include "cfg.h"
#include "psensor.h"
#include "ui.h"
#include "ui_appindicator.h"
};
static guint n_entries = G_N_ELEMENTS(entries);
-static void update_sensor_menu_item(GtkMenuItem *item, struct psensor *s)
+static void update_sensor_menu_item(GtkMenuItem *item,
+ struct psensor *s,
+ int use_celcius)
{
gchar *str;
+ double v;
+
+ v = psensor_get_current_value(s);
+
+ if (is_temp_type(s->type) && !use_celcius)
+ v = celcius_to_fahrenheit(v);
str = g_strdup_printf("%s: %2.f %s",
s->name,
- psensor_get_current_value(s),
- psensor_type_to_unit_str(s->type));
+ v,
+ psensor_type_to_unit_str(s->type, use_celcius));
gtk_menu_item_set_label(item, str);
g_free(str);
}
-static void update_sensor_menu_items(struct psensor **sensors)
+static void update_sensor_menu_items(struct psensor **sensors,
+ int use_celcius)
{
int n, i;
n = psensor_list_size(sensors);
for (i = 0; i < n; i++)
- update_sensor_menu_item(sensor_menu_items[i], sensors[i]);
+ update_sensor_menu_item(sensor_menu_items[i],
+ sensors[i],
+ use_celcius);
}
static GtkWidget *get_menu(struct ui_psensor *ui)
int n = psensor_list_size(ui->sensors);
struct psensor **sensors = ui->sensors;
-
action_group = gtk_action_group_new("PsensorActions");
gtk_action_group_set_translation_domain(action_group, PACKAGE);
menu_manager = gtk_ui_manager_new();
GTK_WIDGET(sensor_menu_items[i]),
i+2);
- update_sensor_menu_item(sensor_menu_items[i],
- s);
+ update_sensor_menu_item
+ (sensor_menu_items[i],
+ s,
+ ui->config->temperature_unit == CELCIUS);
}
app_indicator_set_status
(indicator, APP_INDICATOR_STATUS_ATTENTION);
- update_sensor_menu_items(ui->sensors);
+ update_sensor_menu_items(ui->sensors,
+ ui->config->temperature_unit == CELCIUS);
}
static GtkStatusIcon *unity_fallback(AppIndicator *indicator)
{
+ GtkStatusIcon *ico;
+
log_debug("ui_appindicator#unity_fallback");
appindicator_supported = 0;
- return ui_status_get_icon(ui_psensor);
+ ico = ui_status_get_icon(ui_psensor);
+
+ ui_status_set_visible(1);
+
+ return ico;
}
static void
{
log_debug("ui_appindicator#unity_unfallback");
+ ui_status_set_visible(0);
+
appindicator_supported = 1;
}