/* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*- * * Copyright (C) 2018 Red Hat, Inc * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, see . * * Author: Matthias Clasen */ #include "list-box-helper.h" #include "cc-usage-panel.h" #include "cc-usage-resources.h" #include "cc-util.h" #include #include struct _CcUsagePanel { CcPanel parent_instance; GSettings *privacy_settings; GtkListBox *usage_list_box; GtkSwitch *recently_used_switch; GtkComboBox *retain_history_combo; GtkListBox *trash_list_box; GtkSwitch *purge_trash_switch; GtkSwitch *purge_temp_switch; GtkComboBox *purge_after_combo; GtkButton *purge_temp_button; GtkButton *purge_trash_button; }; CC_PANEL_REGISTER (CcUsagePanel, cc_usage_panel) static void purge_after_combo_changed_cb (CcUsagePanel *self) { GtkTreeIter iter; GtkTreeModel *model; guint value; gboolean ret; /* no selection */ ret = gtk_combo_box_get_active_iter (self->purge_after_combo, &iter); if (!ret) return; /* get entry */ model = gtk_combo_box_get_model (self->purge_after_combo); gtk_tree_model_get (model, &iter, 1, &value, -1); g_settings_set (self->privacy_settings, "old-files-age", "u", value); } static void set_purge_after_value_for_combo (GtkComboBox *combo_box, CcUsagePanel *self) { GtkTreeIter iter; GtkTreeModel *model; guint value; gint value_tmp, value_prev; gboolean ret; guint i; /* get entry */ model = gtk_combo_box_get_model (combo_box); ret = gtk_tree_model_get_iter_first (model, &iter); if (!ret) return; value_prev = 0; i = 0; /* try to make the UI match the purge setting */ g_settings_get (self->privacy_settings, "old-files-age", "u", &value); do { gtk_tree_model_get (model, &iter, 1, &value_tmp, -1); if (value == value_tmp || (value_tmp > value_prev && value < value_tmp)) { gtk_combo_box_set_active_iter (combo_box, &iter); return; } value_prev = value_tmp; i++; } while (gtk_tree_model_iter_next (model, &iter)); /* If we didn't find the setting in the list */ gtk_combo_box_set_active (combo_box, i - 1); } static gboolean run_warning (CcUsagePanel *self, const gchar *prompt, const gchar *text, const gchar *button_title) { GtkWindow *parent; GtkWidget *dialog; GtkWidget *button; int result; parent = GTK_WINDOW (gtk_widget_get_toplevel (GTK_WIDGET (self))); dialog = gtk_message_dialog_new (parent, 0, GTK_MESSAGE_WARNING, GTK_BUTTONS_NONE, NULL); g_object_set (dialog, "text", prompt, "secondary-text", text, NULL); gtk_dialog_add_button (GTK_DIALOG (dialog), _("_Cancel"), GTK_RESPONSE_CANCEL); gtk_dialog_add_button (GTK_DIALOG (dialog), button_title, GTK_RESPONSE_OK); gtk_dialog_set_default_response (GTK_DIALOG (dialog), FALSE); button = gtk_dialog_get_widget_for_response (GTK_DIALOG (dialog), GTK_RESPONSE_OK); gtk_style_context_add_class (gtk_widget_get_style_context (button), "destructive-action"); result = gtk_dialog_run (GTK_DIALOG (dialog)); gtk_widget_destroy (dialog); return result == GTK_RESPONSE_OK; } static void empty_trash (CcUsagePanel *self) { g_autoptr(GDBusConnection) bus = NULL; gboolean result; result = run_warning (self, _("Empty all items from Trash?"), _("All items in the Trash will be permanently deleted."), _("_Empty Trash")); if (!result) return; bus = g_bus_get_sync (G_BUS_TYPE_SESSION, NULL, NULL); g_dbus_connection_call (bus, "org.gnome.SettingsDaemon.Housekeeping", "/org/gnome/SettingsDaemon/Housekeeping", "org.gnome.SettingsDaemon.Housekeeping", "EmptyTrash", NULL, NULL, 0, -1, NULL, NULL, NULL); } static void purge_temp (CcUsagePanel *self) { g_autoptr(GDBusConnection) bus = NULL; gboolean result; result = run_warning (self, _("Delete all the temporary files?"), _("All the temporary files will be permanently deleted."), _("_Purge Temporary Files")); if (!result) return; bus = g_bus_get_sync (G_BUS_TYPE_SESSION, NULL, NULL); g_dbus_connection_call (bus, "org.gnome.SettingsDaemon.Housekeeping", "/org/gnome/SettingsDaemon/Housekeeping", "org.gnome.SettingsDaemon.Housekeeping", "RemoveTempFiles", NULL, NULL, 0, -1, NULL, NULL, NULL); } static void cc_usage_panel_finalize (GObject *object) { CcUsagePanel *self = CC_USAGE_PANEL (object); g_clear_object (&self->privacy_settings); G_OBJECT_CLASS (cc_usage_panel_parent_class)->finalize (object); } static void retain_history_combo_changed_cb (CcUsagePanel *self) { GtkTreeIter iter; GtkTreeModel *model; gint value; gboolean ret; ret = gtk_combo_box_get_active_iter (self->retain_history_combo, &iter); if (!ret) return; model = gtk_combo_box_get_model (self->retain_history_combo); gtk_tree_model_get (model, &iter, 1, &value, -1); g_settings_set (self->privacy_settings, "recent-files-max-age", "i", value); } static void set_retain_history_value_for_combo (GtkComboBox *combo_box, CcUsagePanel *self) { GtkTreeIter iter; GtkTreeModel *model; gint value; gint value_tmp, value_prev; gboolean ret; guint i; model = gtk_combo_box_get_model (combo_box); ret = gtk_tree_model_get_iter_first (model, &iter); if (!ret) return; value_prev = 0; i = 0; g_settings_get (self->privacy_settings, "recent-files-max-age", "i", &value); do { gtk_tree_model_get (model, &iter, 1, &value_tmp, -1); if (value == value_tmp || (value > 0 && value_tmp > value_prev && value < value_tmp)) { gtk_combo_box_set_active_iter (combo_box, &iter); return; } value_prev = value_tmp; i++; } while (gtk_tree_model_iter_next (model, &iter)); gtk_combo_box_set_active (combo_box, i - 1); } static void cc_usage_panel_init (CcUsagePanel *self) { g_resources_register (cc_usage_get_resource ()); gtk_widget_init_template (GTK_WIDGET (self)); gtk_list_box_set_header_func (self->usage_list_box, cc_list_box_update_header_func, NULL, NULL); gtk_list_box_set_header_func (self->trash_list_box, cc_list_box_update_header_func, NULL, NULL); self->privacy_settings = g_settings_new ("org.gnome.desktop.privacy"); g_settings_bind (self->privacy_settings, "remember-recent-files", self->recently_used_switch, "active", G_SETTINGS_BIND_DEFAULT); set_retain_history_value_for_combo (self->retain_history_combo, self); g_signal_connect_object (self->retain_history_combo, "changed", G_CALLBACK (retain_history_combo_changed_cb), self, G_CONNECT_SWAPPED); g_settings_bind (self->privacy_settings, "remember-recent-files", self->retain_history_combo, "sensitive", G_SETTINGS_BIND_GET); g_settings_bind (self->privacy_settings, "remove-old-trash-files", self->purge_trash_switch, "active", G_SETTINGS_BIND_DEFAULT); g_settings_bind (self->privacy_settings, "remove-old-temp-files", self->purge_temp_switch, "active", G_SETTINGS_BIND_DEFAULT); set_purge_after_value_for_combo (self->purge_after_combo, self); g_signal_connect_object (self->purge_after_combo, "changed", G_CALLBACK (purge_after_combo_changed_cb), self, G_CONNECT_SWAPPED); g_signal_connect_object (self->purge_trash_button, "clicked", G_CALLBACK (empty_trash), self, G_CONNECT_SWAPPED); g_signal_connect_object (self->purge_temp_button, "clicked", G_CALLBACK (purge_temp), self, G_CONNECT_SWAPPED); } static void clear_recent (CcUsagePanel *self) { GtkRecentManager *m; m = gtk_recent_manager_get_default (); gtk_recent_manager_purge_items (m, NULL); } static void cc_usage_panel_class_init (CcUsagePanelClass *klass) { GObjectClass *oclass = G_OBJECT_CLASS (klass); GtkWidgetClass *widget_class = GTK_WIDGET_CLASS (klass); oclass->finalize = cc_usage_panel_finalize; gtk_widget_class_set_template_from_resource (widget_class, "/org/gnome/control-center/usage/cc-usage-panel.ui"); gtk_widget_class_bind_template_child (widget_class, CcUsagePanel, purge_after_combo); gtk_widget_class_bind_template_child (widget_class, CcUsagePanel, purge_temp_switch); gtk_widget_class_bind_template_child (widget_class, CcUsagePanel, purge_trash_button); gtk_widget_class_bind_template_child (widget_class, CcUsagePanel, purge_trash_switch); gtk_widget_class_bind_template_child (widget_class, CcUsagePanel, purge_temp_button); gtk_widget_class_bind_template_child (widget_class, CcUsagePanel, recently_used_switch); gtk_widget_class_bind_template_child (widget_class, CcUsagePanel, retain_history_combo); gtk_widget_class_bind_template_child (widget_class, CcUsagePanel, trash_list_box); gtk_widget_class_bind_template_child (widget_class, CcUsagePanel, usage_list_box); gtk_widget_class_bind_template_callback (widget_class, clear_recent); }