diff options
Diffstat (limited to 'plugins')
-rw-r--r-- | plugins/backup-restore/ChangeLog | 7 | ||||
-rw-r--r-- | plugins/backup-restore/backup.c | 89 |
2 files changed, 81 insertions, 15 deletions
diff --git a/plugins/backup-restore/ChangeLog b/plugins/backup-restore/ChangeLog index f59c307f8d..ef5588c2bb 100644 --- a/plugins/backup-restore/ChangeLog +++ b/plugins/backup-restore/ChangeLog @@ -1,3 +1,10 @@ +2008-06-19 Milan Crha <mcrha@redhat.com> + + ** Fix for bug #478469 + + * backup.c: (main): + Changed the progress dialog to be more HIG compliant. + 2008-05-20 Sankar P <psankar@novell.com> * backup-restore.c: (epbr_perform_pre_backup_checks), diff --git a/plugins/backup-restore/backup.c b/plugins/backup-restore/backup.c index 6b8f418a97..114d04f7dc 100644 --- a/plugins/backup-restore/backup.c +++ b/plugins/backup-restore/backup.c @@ -262,9 +262,10 @@ main (int argc, char **argv) } } - if (gui_arg) { - GtkWidget *vbox, *hbox, *label; - char *str=NULL; + if (gui_arg && !check_op) { + GtkWidget *widget, *container; + char *str = NULL, *txt; + const char *txt2; /* Backup / Restore only can have GUI. We should restrict the rest */ progress_dialog = gtk_dialog_new_with_buttons (backup_op ? _("Evolution Backup"): _("Evolution Restore"), @@ -274,25 +275,83 @@ main (int argc, char **argv) GTK_RESPONSE_REJECT, NULL); + gtk_dialog_set_has_separator (GTK_DIALOG (progress_dialog), FALSE); + gtk_container_set_border_width (GTK_CONTAINER (progress_dialog), 12); + + /* Override GtkDialog defaults */ + widget = GTK_DIALOG (progress_dialog)->vbox; + gtk_box_set_spacing (GTK_BOX (widget), 12); + gtk_container_set_border_width (GTK_CONTAINER (widget), 0); + widget = GTK_DIALOG (progress_dialog)->action_area; + gtk_box_set_spacing (GTK_BOX (widget), 12); + gtk_container_set_border_width (GTK_CONTAINER (widget), 0); + if (oper && file) str = g_strdup_printf(oper, file); - vbox = gtk_vbox_new (FALSE, 6); - if (str) { - hbox = gtk_hbox_new (FALSE, 12); - label = gtk_label_new (str); - g_free (str); - gtk_box_pack_start ((GtkBox *)hbox, label, FALSE, FALSE, 6); - gtk_box_pack_start ((GtkBox *)vbox, hbox, FALSE, FALSE, 6); + container = gtk_table_new (2, 3, FALSE); + gtk_table_set_col_spacings (GTK_TABLE (container), 12); + gtk_table_set_row_spacings (GTK_TABLE (container), 12); + gtk_widget_show (container); + + gtk_box_pack_start (GTK_BOX (GTK_DIALOG (progress_dialog)->vbox), container, FALSE, TRUE, 0); + + widget = gtk_image_new_from_stock (GTK_STOCK_COPY, GTK_ICON_SIZE_DIALOG); + gtk_misc_set_alignment (GTK_MISC (widget), 0.0, 0.0); + gtk_widget_show (widget); + + gtk_table_attach (GTK_TABLE (container), widget, 0, 1, 0, 3, GTK_FILL, GTK_EXPAND | GTK_FILL, 0, 0); + + if (backup_op) { + txt = _("Backing up Evolution Data"); + txt2 = _("Please wait while Evolution is backing up your data."); + } else if (restore_op) { + txt = _("Restoring Evolution Data"); + txt2 = _("Please wait while Evolution is restoring your data."); + } else { + /* do not translate these two, it's just a fallback when something goes wrong, + we should never get here anyway. */ + txt = "Oops, doing nothing..."; + txt2 = "Should not be here now, really..."; } - hbox = gtk_hbox_new (FALSE, 12); + + txt = g_strconcat ("<b><big>", txt, "</big></b>", NULL); + widget = gtk_label_new (NULL); + gtk_label_set_line_wrap (GTK_LABEL (widget), FALSE); + gtk_label_set_markup (GTK_LABEL (widget), txt); + gtk_misc_set_alignment (GTK_MISC (widget), 0.0, 0.0); + gtk_widget_show (widget); + g_free (txt); + + gtk_table_attach (GTK_TABLE (container), widget, 1, 2, 0, 1, GTK_EXPAND | GTK_FILL, GTK_FILL, 0, 0); + + txt = g_strconcat (txt2, " ", _("This may take a while depending on the amount of data in your account."), NULL); + widget = gtk_label_new (NULL); + gtk_label_set_line_wrap (GTK_LABEL (widget), TRUE); + gtk_label_set_markup (GTK_LABEL (widget), txt); + gtk_misc_set_alignment (GTK_MISC (widget), 0.0, 0.5); + gtk_widget_show (widget); + g_free (txt); + + gtk_table_attach (GTK_TABLE (container), widget, 1, 2, 1, 2, GTK_EXPAND | GTK_FILL, GTK_FILL, 0, 0); + pbar = gtk_progress_bar_new (); - gtk_box_pack_start ((GtkBox *)hbox, pbar, TRUE, TRUE, 6); - gtk_box_pack_start ((GtkBox *)vbox, hbox, FALSE, FALSE, 0); + if (str) { + txt = g_strconcat ("<i>", str, "</i>", NULL); + widget = gtk_label_new (NULL); + gtk_label_set_markup (GTK_LABEL (widget), txt); + gtk_misc_set_alignment (GTK_MISC (widget), 0.0, 0.5); + g_free (txt); + g_free (str); + gtk_table_attach (GTK_TABLE (container), widget, 1, 2, 2, 3, GTK_EXPAND | GTK_FILL, GTK_FILL, 0, 0); + gtk_table_set_row_spacing (GTK_TABLE (container), 2, 6); + + gtk_table_attach (GTK_TABLE (container), pbar, 1, 2, 3, 4, GTK_EXPAND | GTK_FILL, GTK_FILL, 0, 0); + } else + gtk_table_attach (GTK_TABLE (container), pbar, 1, 2, 2, 3, GTK_EXPAND | GTK_FILL, GTK_FILL, 0, 0); - gtk_container_add (GTK_CONTAINER (GTK_DIALOG(progress_dialog)->vbox), vbox); - gtk_window_set_default_size ((GtkWindow *) progress_dialog,450, 120); + gtk_window_set_default_size ((GtkWindow *) progress_dialog, 450, 120); g_signal_connect (progress_dialog, "response", G_CALLBACK(dlg_response), NULL); gtk_widget_show_all (progress_dialog); } else if (check_op) { |