#include <stdlib.h>
#include <string.h>
-#include <ui.h>
+#include <amd.h>
#include <cfg.h>
-#include <ui_pref.h>
-#include <ui_color.h>
+#include <graph.h>
+#include <hdd.h>
+#include <lmsensor.h>
+#include <nvidia.h>
+#include <pgtop2.h>
+#include <pudisks2.h>
#include <pxdg.h>
+#include <ui.h>
+#include <ui_color.h>
+#include <ui_pref.h>
+#include <ui_unity.h>
+
+void ui_pref_decoration_toggled_cbk(GtkToggleButton *btn, gpointer data)
+{
+ config_set_window_decoration_enabled
+ (!gtk_toggle_button_get_active(btn));
+}
+
+void ui_pref_keep_below_toggled_cbk(GtkToggleButton *btn, gpointer data)
+{
+ config_set_window_keep_below_enabled
+ (gtk_toggle_button_get_active(btn));
+}
+
+void ui_pref_temperature_unit_changed_cbk(GtkComboBox *combo, gpointer data)
+{
+ config_set_temperature_unit(gtk_combo_box_get_active(combo));
+}
+
+void ui_pref_menu_toggled_cbk(GtkToggleButton *btn, gpointer data)
+{
+ config_set_menu_bar_enabled(gtk_toggle_button_get_active(btn));
+}
+
+void ui_pref_count_visible_toggled_cbk(GtkToggleButton *btn, gpointer data)
+{
+ config_set_count_visible(gtk_toggle_button_get_active(btn));
+}
+
+void ui_pref_sensorlist_position_changed_cbk(GtkComboBox *combo, gpointer data)
+{
+ config_set_sensorlist_position(gtk_combo_box_get_active(combo));
+}
GdkRGBA color_to_GdkRGBA(struct color *color)
{
GtkSpinButton *w_update_interval, *w_monitoring_duration,
*w_s_update_interval, *w_slog_interval;
GtkComboBox *w_sensorlist_pos;
- GtkToggleButton *w_hide_window_decoration, *w_keep_window_below,
- *w_enable_menu, *w_enable_launcher_counter, *w_hide_on_startup,
- *w_win_restore, *w_slog_enabled, *w_autostart;
+ GtkToggleButton *w_enable_menu, *w_enable_launcher_counter,
+ *w_hide_on_startup, *w_win_restore, *w_slog_enabled,
+ *w_autostart, *w_smooth_curves, *w_atiadlsdk, *w_lmsensors,
+ *w_nvctrl, *w_gtop2, *w_hddtemp, *w_libatasmart, *w_udisks2,
+ *w_decoration, *w_keep_below;
GtkComboBoxText *w_temp_unit;
GtkEntry *w_notif_script;
char *notif_script;
gtk_spin_button_set_value(w_s_update_interval,
cfg->sensor_update_interval);
+ w_decoration = GTK_TOGGLE_BUTTON(gtk_builder_get_object
+ (builder, "hide_window_decoration"));
+ gtk_toggle_button_set_active(w_decoration,
+ !config_is_window_decoration_enabled());
+
+ w_keep_below = GTK_TOGGLE_BUTTON(gtk_builder_get_object
+ (builder, "keep_window_below"));
+ gtk_toggle_button_set_active(w_keep_below,
+ config_is_window_keep_below_enabled());
+
w_monitoring_duration
= GTK_SPIN_BUTTON(gtk_builder_get_object
(builder, "monitoring_duration"));
w_sensorlist_pos = GTK_COMBO_BOX
(gtk_builder_get_object(builder, "sensors_list_position"));
- gtk_combo_box_set_active(w_sensorlist_pos, cfg->sensorlist_position);
-
- w_hide_window_decoration = GTK_TOGGLE_BUTTON
- (gtk_builder_get_object(builder, "hide_window_decoration"));
- gtk_toggle_button_set_active(w_hide_window_decoration,
- !cfg->window_decoration_enabled);
-
- w_keep_window_below = GTK_TOGGLE_BUTTON
- (gtk_builder_get_object(builder, "keep_window_below"));
- gtk_toggle_button_set_active(w_keep_window_below,
- cfg->window_keep_below_enabled);
+ gtk_combo_box_set_active(w_sensorlist_pos,
+ config_get_sensorlist_position());
w_autostart = GTK_TOGGLE_BUTTON
(gtk_builder_get_object(builder, "autostart"));
w_enable_menu = GTK_TOGGLE_BUTTON
(gtk_builder_get_object(builder, "enable_menu"));
- gtk_toggle_button_set_active(w_enable_menu, !cfg->menu_bar_disabled);
+ gtk_toggle_button_set_active(w_enable_menu,
+ config_is_menu_bar_enabled());
w_enable_launcher_counter = GTK_TOGGLE_BUTTON
(gtk_builder_get_object(builder, "enable_launcher_counter"));
gtk_toggle_button_set_active(w_enable_launcher_counter,
- !cfg->unity_launcher_count_disabled);
+ !config_is_count_visible());
+
+ if (ui_unity_is_supported()) {
+ gtk_widget_set_has_tooltip
+ (GTK_WIDGET(w_enable_launcher_counter), FALSE);
+ } else {
+ gtk_widget_set_sensitive
+ (GTK_WIDGET(w_enable_launcher_counter), FALSE);
+ gtk_widget_set_has_tooltip
+ (GTK_WIDGET(w_enable_launcher_counter), TRUE);
+ }
+
+ w_smooth_curves = GTK_TOGGLE_BUTTON
+ (gtk_builder_get_object(builder, "graph_smooth_curves"));
+ gtk_toggle_button_set_active(w_smooth_curves,
+ config_is_smooth_curves_enabled());
w_slog_enabled = GTK_TOGGLE_BUTTON
(gtk_builder_get_object(builder, "enable_slog"));
= GTK_COMBO_BOX_TEXT(gtk_builder_get_object
(builder, "temperature_unit"));
gtk_combo_box_set_active(GTK_COMBO_BOX(w_temp_unit),
- cfg->temperature_unit);
+ config_get_temperature_unit());
+
+ /* providers */
+ w_lmsensors
+ = GTK_TOGGLE_BUTTON(gtk_builder_get_object(builder,
+ "lmsensors"));
+ gtk_toggle_button_set_active(w_lmsensors, config_is_lmsensor_enabled());
+
+ if (lmsensor_is_supported()) {
+ gtk_widget_set_has_tooltip(GTK_WIDGET(w_lmsensors), FALSE);
+ } else {
+ gtk_widget_set_sensitive(GTK_WIDGET(w_lmsensors), 0);
+ gtk_widget_set_has_tooltip(GTK_WIDGET(w_lmsensors), TRUE);
+ }
+
+ w_nvctrl
+ = GTK_TOGGLE_BUTTON(gtk_builder_get_object(builder,
+ "nvctrl"));
+
+ if (nvidia_is_supported()) {
+ gtk_widget_set_has_tooltip(GTK_WIDGET(w_nvctrl), FALSE);
+ } else {
+ gtk_widget_set_sensitive(GTK_WIDGET(w_nvctrl), 0);
+ gtk_widget_set_has_tooltip(GTK_WIDGET(w_nvctrl), TRUE);
+ }
+
+ gtk_toggle_button_set_active(w_nvctrl, config_is_nvctrl_enabled());
+
+ w_atiadlsdk
+ = GTK_TOGGLE_BUTTON(gtk_builder_get_object(builder,
+ "atiadlsdk"));
+ if (amd_is_supported()) {
+ gtk_widget_set_has_tooltip(GTK_WIDGET(w_atiadlsdk), FALSE);
+ } else {
+ gtk_widget_set_sensitive(GTK_WIDGET(w_atiadlsdk), 0);
+ gtk_widget_set_has_tooltip(GTK_WIDGET(w_atiadlsdk), TRUE);
+ }
+
+ gtk_toggle_button_set_active(w_atiadlsdk,
+ config_is_atiadlsdk_enabled());
+
+ w_gtop2
+ = GTK_TOGGLE_BUTTON(gtk_builder_get_object(builder,
+ "gtop2"));
+
+ if (gtop2_is_supported()) {
+ gtk_widget_set_has_tooltip(GTK_WIDGET(w_gtop2), FALSE);
+ } else {
+ gtk_widget_set_sensitive(GTK_WIDGET(w_gtop2), 0);
+ gtk_widget_set_has_tooltip(GTK_WIDGET(w_gtop2), TRUE);
+ }
+
+ gtk_toggle_button_set_active(w_gtop2, config_is_gtop2_enabled());
+
+ w_hddtemp
+ = GTK_TOGGLE_BUTTON(gtk_builder_get_object(builder,
+ "hddtemp"));
+ gtk_toggle_button_set_active(w_hddtemp, config_is_hddtemp_enabled());
+
+
+ w_libatasmart
+ = GTK_TOGGLE_BUTTON(gtk_builder_get_object(builder,
+ "libatasmart"));
+
+ if (atasmart_is_supported()) {
+ gtk_widget_set_has_tooltip(GTK_WIDGET(w_libatasmart), FALSE);
+ } else {
+ gtk_widget_set_sensitive(GTK_WIDGET(w_libatasmart), 0);
+ gtk_widget_set_has_tooltip(GTK_WIDGET(w_libatasmart), TRUE);
+ }
+
+ gtk_toggle_button_set_active(w_libatasmart,
+ config_is_libatasmart_enabled());
+
+ w_udisks2
+ = GTK_TOGGLE_BUTTON(gtk_builder_get_object(builder,
+ "udisks2"));
+
+ if (udisks2_is_supported()) {
+ gtk_widget_set_has_tooltip(GTK_WIDGET(w_udisks2), FALSE);
+ } else {
+ gtk_widget_set_sensitive(GTK_WIDGET(w_udisks2), 0);
+ gtk_widget_set_has_tooltip(GTK_WIDGET(w_udisks2), TRUE);
+ }
+
+ gtk_toggle_button_set_active(w_udisks2, config_is_udisks2_enabled());
+
+ gtk_builder_connect_signals(builder, NULL);
result = gtk_dialog_run(diag);
else
cfg->alpha_channel_enabled = 1;
- cfg->sensorlist_position
- = gtk_combo_box_get_active(w_sensorlist_pos);
-
- cfg->window_decoration_enabled =
- !gtk_toggle_button_get_active(w_hide_window_decoration);
-
- cfg->window_keep_below_enabled
- = gtk_toggle_button_get_active(w_keep_window_below);
-
- cfg->menu_bar_disabled
- = !gtk_toggle_button_get_active(w_enable_menu);
-
- cfg->unity_launcher_count_disabled
- = !gtk_toggle_button_get_active
- (w_enable_launcher_counter);
-
- gtk_window_set_decorated(GTK_WINDOW(ui->main_window),
- cfg->window_decoration_enabled);
-
- gtk_window_set_keep_below(GTK_WINDOW(ui->main_window),
- cfg->window_keep_below_enabled);
-
cfg->sensor_update_interval
= gtk_spin_button_get_value_as_int(w_s_update_interval);
= gtk_spin_button_get_value_as_int
(w_monitoring_duration);
- cfg->sensor_values_max_length
- = (cfg->graph_monitoring_duration * 60) /
- cfg->sensor_update_interval;
-
cfg->hide_on_startup
= gtk_toggle_button_get_active(w_hide_on_startup);
cfg->slog_interval
= gtk_spin_button_get_value_as_int(w_slog_interval);
- cfg->temperature_unit
- = gtk_combo_box_get_active(GTK_COMBO_BOX(w_temp_unit));
+ cfg->sensor_values_max_length = compute_values_max_length(cfg);
config_save(cfg);
+ config_set_smooth_curves_enabled
+ (gtk_toggle_button_get_active(w_smooth_curves));
+
+ config_set_lmsensor_enable
+ (gtk_toggle_button_get_active(w_lmsensors));
+
+ config_set_nvctrl_enable
+ (gtk_toggle_button_get_active(w_nvctrl));
+
+ config_set_atiadlsdk_enable
+ (gtk_toggle_button_get_active(w_atiadlsdk));
+
+ config_set_gtop2_enable
+ (gtk_toggle_button_get_active(w_gtop2));
+
+ config_set_hddtemp_enable
+ (gtk_toggle_button_get_active(w_hddtemp));
+
+ config_set_libatasmart_enable
+ (gtk_toggle_button_get_active(w_libatasmart));
+
+ config_set_udisks2_enable
+ (gtk_toggle_button_get_active(w_udisks2));
+
pxdg_set_autostart(gtk_toggle_button_get_active(w_autostart));
pthread_mutex_unlock(&ui->sensors_mutex);