/* -*- 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 "cc-usage-panel.h" #include "cc-usage-panel-enums.h" #include "cc-usage-resources.h" #include "cc-util.h" #include #include struct _CcUsagePanel { CcPanel parent_instance; GSettings *privacy_settings; GtkSwitch *recently_used_switch; AdwComboRow *retain_history_combo; GtkSwitch *purge_trash_switch; GtkSwitch *purge_temp_switch; AdwComboRow *purge_after_combo; GtkButton *purge_temp_button; GtkButton *purge_trash_button; }; CC_PANEL_REGISTER (CcUsagePanel, cc_usage_panel) static char * purge_after_name_cb (AdwEnumListItem *item, gpointer user_data) { switch (adw_enum_list_item_get_value (item)) { case CC_USAGE_PANEL_PURGE_AFTER_1_HOUR: /* Translators: Option for "Automatically Delete Period" in "Trash & Temporary Files" group */ return g_strdup (C_("purge_files", "1 hour")); case CC_USAGE_PANEL_PURGE_AFTER_1_DAY: /* Translators: Option for "Automatically Delete Period" in "Trash & Temporary Files" group */ return g_strdup (C_("purge_files", "1 day")); case CC_USAGE_PANEL_PURGE_AFTER_2_DAYS: /* Translators: Option for "Automatically Delete Period" in "Trash & Temporary Files" group */ return g_strdup (C_("purge_files", "2 days")); case CC_USAGE_PANEL_PURGE_AFTER_3_DAYS: /* Translators: Option for "Automatically Delete Period" in "Trash & Temporary Files" group */ return g_strdup (C_("purge_files", "3 days")); case CC_USAGE_PANEL_PURGE_AFTER_4_DAYS: /* Translators: Option for "Automatically Delete Period" in "Trash & Temporary Files" group */ return g_strdup (C_("purge_files", "4 days")); case CC_USAGE_PANEL_PURGE_AFTER_5_DAYS: /* Translators: Option for "Automatically Delete Period" in "Trash & Temporary Files" group */ return g_strdup (C_("purge_files", "5 days")); case CC_USAGE_PANEL_PURGE_AFTER_6_DAYS: /* Translators: Option for "Automatically Delete Period" in "Trash & Temporary Files" group */ return g_strdup (C_("purge_files", "6 days")); case CC_USAGE_PANEL_PURGE_AFTER_7_DAYS: /* Translators: Option for "Automatically Delete Period" in "Trash & Temporary Files" group */ return g_strdup (C_("purge_files", "7 days")); case CC_USAGE_PANEL_PURGE_AFTER_14_DAYS: /* Translators: Option for "Automatically Delete Period" in "Trash & Temporary Files" group */ return g_strdup (C_("purge_files", "14 days")); case CC_USAGE_PANEL_PURGE_AFTER_30_DAYS: /* Translators: Option for "Automatically Delete Period" in "Trash & Temporary Files" group */ return g_strdup (C_("purge_files", "30 days")); default: return NULL; } } static void purge_after_combo_changed_cb (AdwComboRow *combo_row, GParamSpec *pspec, CcUsagePanel *self) { AdwEnumListItem *item; CcUsagePanelPurgeAfter value; item = ADW_ENUM_LIST_ITEM (adw_combo_row_get_selected_item (combo_row)); value = adw_enum_list_item_get_value (item); g_settings_set (self->privacy_settings, "old-files-age", "u", value); } static void set_purge_after_value_for_combo (AdwComboRow *combo_row, CcUsagePanel *self) { AdwEnumListModel *model; guint value; model = ADW_ENUM_LIST_MODEL (adw_combo_row_get_model (combo_row)); g_settings_get (self->privacy_settings, "old-files-age", "u", &value); adw_combo_row_set_selected (combo_row, adw_enum_list_model_find_position (model, value)); } static GtkDialog * run_warning (CcUsagePanel *self, const gchar *prompt, const gchar *text, const gchar *button_title) { GtkWindow *parent; GtkWidget *dialog; GtkWidget *button; CcShell *shell; shell = cc_panel_get_shell (CC_PANEL (self)); parent = GTK_WINDOW (cc_shell_get_toplevel (shell)); dialog = gtk_message_dialog_new (parent, GTK_DIALOG_MODAL | GTK_DIALOG_DESTROY_WITH_PARENT, 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"); gtk_window_present (GTK_WINDOW (dialog)); return GTK_DIALOG (dialog); } static void on_empty_trash_warning_response_cb (GtkDialog *dialog, gint response, CcUsagePanel *self) { g_autoptr(GDBusConnection) bus = NULL; if (response != GTK_RESPONSE_OK) goto out; 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); out: gtk_window_destroy (GTK_WINDOW (dialog)); } static void empty_trash (CcUsagePanel *self) { GtkDialog *dialog; dialog = run_warning (self, _("Empty all items from Trash?"), _("All items in the Trash will be permanently deleted."), _("_Empty Trash")); g_signal_connect_object (dialog, "response", G_CALLBACK (on_empty_trash_warning_response_cb), self, 0); } static void on_purge_temp_warning_response_cb (GtkDialog *dialog, gint response, CcUsagePanel *self) { g_autoptr(GDBusConnection) bus = NULL; if (response != GTK_RESPONSE_OK) goto out; 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); out: gtk_window_destroy (GTK_WINDOW (dialog)); } static void purge_temp (CcUsagePanel *self) { GtkDialog *dialog; dialog = run_warning (self, _("Delete all the temporary files?"), _("All the temporary files will be permanently deleted."), _("_Purge Temporary Files")); g_signal_connect_object (dialog, "response", G_CALLBACK (on_purge_temp_warning_response_cb), self, 0); } 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 char * retain_history_name_cb (AdwEnumListItem *item, gpointer user_data) { switch (adw_enum_list_item_get_value (item)) { case CC_USAGE_PANEL_RETAIN_HISTORY_1_DAY: /* Translators: Option for "File History Duration" in "File History" group */ return g_strdup (C_("retain_history", "1 day")); case CC_USAGE_PANEL_RETAIN_HISTORY_7_DAYS: /* Translators: Option for "File History Duration" in "File History" group */ return g_strdup (C_("retain_history", "7 days")); case CC_USAGE_PANEL_RETAIN_HISTORY_30_DAYS: /* Translators: Option for "File History Duration" in "File History" group */ return g_strdup (C_("retain_history", "30 days")); case CC_USAGE_PANEL_RETAIN_HISTORY_FOREVER: /* Translators: Option for "File History Duration" in "File History" group */ return g_strdup (C_("retain_history", "Forever")); default: return NULL; } } static void retain_history_combo_changed_cb (AdwComboRow *combo_row, GParamSpec *pspec, CcUsagePanel *self) { AdwEnumListItem *item; CcUsagePanelRetainHistory value; item = ADW_ENUM_LIST_ITEM (adw_combo_row_get_selected_item (combo_row)); value = adw_enum_list_item_get_value (item); g_settings_set (self->privacy_settings, "recent-files-max-age", "i", value); } static void set_retain_history_value_for_combo (AdwComboRow *combo_row, CcUsagePanel *self) { AdwEnumListModel *model; gint value; model = ADW_ENUM_LIST_MODEL (adw_combo_row_get_model (combo_row)); g_settings_get (self->privacy_settings, "recent-files-max-age", "i", &value); adw_combo_row_set_selected (combo_row, adw_enum_list_model_find_position (model, value)); } static void cc_usage_panel_init (CcUsagePanel *self) { g_resources_register (cc_usage_get_resource ()); g_type_ensure (CC_TYPE_USAGE_PANEL_PURGE_AFTER); g_type_ensure (CC_TYPE_USAGE_PANEL_RETAIN_HISTORY); gtk_widget_init_template (GTK_WIDGET (self)); 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_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_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_callback (widget_class, clear_recent); gtk_widget_class_bind_template_callback (widget_class, retain_history_name_cb); gtk_widget_class_bind_template_callback (widget_class, retain_history_combo_changed_cb); gtk_widget_class_bind_template_callback (widget_class, purge_after_name_cb); gtk_widget_class_bind_template_callback (widget_class, purge_after_combo_changed_cb); }