2 * Copyright (C) 2010-2014 jeanfi@gmail.com
4 * This program is free software; you can redistribute it and/or
5 * modify it under the terms of the GNU General Public License as
6 * published by the Free Software Foundation; either version 2 of the
7 * License, or (at your option) any later version.
9 * This program is distributed in the hope that it will be useful, but
10 * WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 * General Public License for more details.
14 * You should have received a copy of the GNU General Public License
15 * along with this program; if not, write to the Free Software
16 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
24 #include <libappindicator/app-indicator.h>
29 #include "ui_appindicator.h"
30 #include "ui_sensorpref.h"
31 #include "ui_status.h"
34 static const char *ICON = "psensor_normal";
35 static const char *ATTENTION_ICON = "psensor_hot";
37 static struct psensor **sensors;
38 static GtkMenuItem **menu_items;
39 static int appindicator_supported = 1;
40 static AppIndicator *indicator;
41 static struct ui_psensor *ui_psensor;
43 void cb_menu_show(GtkMenuItem *mi, gpointer data)
45 ui_window_show((struct ui_psensor *)data);
48 void ui_appindicator_cb_preferences(GtkMenuItem *mi, gpointer data)
50 #ifdef HAVE_APPINDICATOR_029
54 ui_pref_dialog_run((struct ui_psensor *)data);
56 #ifdef HAVE_APPINDICATOR_029
61 void ui_appindicator_cb_sensor_preferences(GtkMenuItem *mi, gpointer data)
63 struct ui_psensor *ui = data;
65 #ifdef HAVE_APPINDICATOR_029
69 if (ui->sensors && *ui->sensors)
70 ui_sensorpref_dialog_run(*ui->sensors, ui);
72 #ifdef HAVE_APPINDICATOR_029
78 update_menu_item(GtkMenuItem *item, struct psensor *s, int use_celsius)
83 v = psensor_current_value_to_str(s, use_celsius);
85 str = g_strdup_printf("%s: %s", s->name, v);
87 gtk_menu_item_set_label(item, str);
93 static void update_menu_items(int use_celsius)
101 for (s = sensors, m = menu_items; *s; s++, m++)
102 update_menu_item(*m, *s, use_celsius);
106 build_sensor_menu_items(const struct ui_psensor *ui, GtkMenu *menu)
108 int i, j, n, celsius;
110 struct psensor **sorted_sensors;
114 celsius = ui->config->temperature_unit == CELSIUS;
116 sorted_sensors = ui_get_sensors_ordered_by_position(ui);
117 n = psensor_list_size(sorted_sensors);
118 menu_items = malloc(n * sizeof(GtkWidget *));
119 sensors = malloc((n + 1) * sizeof(struct psensor *));
120 for (i = 0, j = 0; i < n; i++) {
121 if (config_is_appindicator_enabled(sorted_sensors[i]->id)) {
122 sensors[j] = sorted_sensors[i];
123 name = sensors[j]->name;
125 menu_items[j] = GTK_MENU_ITEM
126 (gtk_menu_item_new_with_label(name));
128 gtk_menu_shell_insert(GTK_MENU_SHELL(menu),
129 GTK_WIDGET(menu_items[j]),
132 update_menu_item(menu_items[j], sensors[j], celsius);
140 free(sorted_sensors);
143 static GtkWidget *get_menu(struct ui_psensor *ui)
150 builder = gtk_builder_new();
153 ok = gtk_builder_add_from_file
155 PACKAGE_DATA_DIR G_DIR_SEPARATOR_S "psensor.glade",
159 log_printf(LOG_ERR, error->message);
164 menu = GTK_MENU(gtk_builder_get_object(builder, "appindicator_menu"));
165 build_sensor_menu_items(ui, menu);
166 gtk_builder_connect_signals(builder, ui);
168 g_object_ref(G_OBJECT(menu));
169 g_object_unref(G_OBJECT(builder));
171 return GTK_WIDGET(menu);
174 static void update_label(struct ui_psensor *ui)
176 char *label, *str, *tmp, *guide;
179 p = ui_get_sensors_ordered_by_position(ui);
183 if (config_is_appindicator_label_enabled((*p)->id)) {
184 str = psensor_current_value_to_str
185 (*p, ui->config->temperature_unit == CELSIUS);
190 tmp = malloc(strlen(label)
194 sprintf(tmp, "%s %s", label, str);
200 if (is_temp_type((*p)->type))
202 else if (is_fan_type((*p)->type))
210 tmp = malloc(strlen(guide)
214 sprintf(tmp, "%sW%s", guide, str);
223 app_indicator_set_label(indicator, label, guide);
226 void ui_appindicator_update(struct ui_psensor *ui, unsigned int attention)
228 AppIndicatorStatus status;
235 status = app_indicator_get_status(indicator);
237 if (!attention && status == APP_INDICATOR_STATUS_ATTENTION)
238 app_indicator_set_status(indicator,
239 APP_INDICATOR_STATUS_ACTIVE);
241 if (attention && status == APP_INDICATOR_STATUS_ACTIVE)
242 app_indicator_set_status(indicator,
243 APP_INDICATOR_STATUS_ATTENTION);
245 update_menu_items(ui->config->temperature_unit == CELSIUS);
248 static GtkStatusIcon *unity_fallback(AppIndicator *indicator)
252 log_debug("ui_appindicator.unity_fallback()");
254 appindicator_supported = 0;
256 ico = ui_status_get_icon(ui_psensor);
258 ui_status_set_visible(1);
264 unity_unfallback(AppIndicator *indicator, GtkStatusIcon *status_icon)
266 log_debug("ui_appindicator.unity_unfallback()");
268 ui_status_set_visible(0);
270 appindicator_supported = 1;
273 void ui_appindicator_update_menu(struct ui_psensor *ui)
278 app_indicator_set_menu(indicator, GTK_MENU(menu));
280 gtk_widget_show_all(menu);
283 void ui_appindicator_init(struct ui_psensor *ui)
287 indicator = app_indicator_new
290 APP_INDICATOR_CATEGORY_APPLICATION_STATUS);
292 APP_INDICATOR_GET_CLASS(indicator)->fallback = unity_fallback;
293 APP_INDICATOR_GET_CLASS(indicator)->unfallback = unity_unfallback;
295 app_indicator_set_status(indicator, APP_INDICATOR_STATUS_ACTIVE);
296 app_indicator_set_attention_icon(indicator, ATTENTION_ICON);
298 ui_appindicator_update_menu(ui);
301 int is_appindicator_supported()
303 return appindicator_supported;
306 void ui_appindicator_cleanup()