diff options
Diffstat (limited to 'embed')
-rw-r--r-- | embed/mozilla/PrintingPromptService.cpp | 33 | ||||
-rw-r--r-- | embed/mozilla/mozilla-embed.cpp | 9 | ||||
-rwxr-xr-x | embed/print-dialog.c | 590 | ||||
-rw-r--r-- | embed/print-dialog.h | 54 |
4 files changed, 262 insertions, 424 deletions
diff --git a/embed/mozilla/PrintingPromptService.cpp b/embed/mozilla/PrintingPromptService.cpp index cab6b9b22..3a2bd63ae 100644 --- a/embed/mozilla/PrintingPromptService.cpp +++ b/embed/mozilla/PrintingPromptService.cpp @@ -26,6 +26,7 @@ #include "print-dialog.h" #include "ephy-embed.h" +#include "ephy-command-manager.h" #include "MozillaPrivate.h" #include "PrintingPromptService.h" @@ -49,27 +50,37 @@ GPrintingPromptService::~GPrintingPromptService() NS_IMETHODIMP GPrintingPromptService::ShowPrintDialog(nsIDOMWindow *parent, nsIWebBrowserPrint *webBrowserPrint, nsIPrintSettings *printSettings) { EphyDialog *dialog; - EmbedPrintInfo *info; - nsresult rv = NS_OK; + nsresult rv = NS_ERROR_ABORT; GtkWidget *gtkParent = MozillaFindGtkParent(parent); + if (!gtkParent) return NS_ERROR_ABORT; + EphyEmbed *embed = EPHY_EMBED (MozillaFindEmbed (parent)); + if (!embed) return NS_ERROR_ABORT; - dialog = print_dialog_new_with_parent (gtkParent, embed, &info); + dialog = ephy_print_dialog_new (gtkParent, embed, TRUE); ephy_dialog_set_modal (dialog, TRUE); - gint ret = ephy_dialog_run (dialog); - if(ret == GTK_RESPONSE_OK) + int ret = ephy_dialog_run (dialog); + if (ret == GTK_RESPONSE_OK) { - MozillaCollatePrintSettings(info, printSettings); - print_free_info(info); + EmbedPrintInfo *info; + + info = ephy_print_get_print_info (); + + /* work around mozilla bug which borks when printing selection without having one */ + if (info->pages == 2 && ephy_command_manager_can_do_command + (EPHY_COMMAND_MANAGER (embed), "cmd_copy") == FALSE) + { + info->pages = 0; + } + + MozillaCollatePrintSettings (info, printSettings); + + ephy_print_info_free (info); rv = NS_OK; } - else - { - rv = NS_ERROR_ABORT; - } g_object_unref (dialog); diff --git a/embed/mozilla/mozilla-embed.cpp b/embed/mozilla/mozilla-embed.cpp index c031664af..297b64747 100644 --- a/embed/mozilla/mozilla-embed.cpp +++ b/embed/mozilla/mozilla-embed.cpp @@ -703,7 +703,14 @@ impl_print (EphyEmbed *embed, nsCOMPtr<nsIPrintSettings> options; result = mpriv->browser->GetPrintSettings(getter_AddRefs(options)); - if (!NS_SUCCEEDED (result)) return; + if (NS_FAILED (result) || !options) return; + + /* work around mozilla bug which borks when printing selection without having one */ + if (info->pages == 2 && ephy_command_manager_can_do_command + (EPHY_COMMAND_MANAGER (embed), "cmd_copy") == FALSE) + { + info->pages = 0; + } MozillaCollatePrintSettings(info, options); diff --git a/embed/print-dialog.c b/embed/print-dialog.c index e09b1a6c9..fed912b78 100755 --- a/embed/print-dialog.c +++ b/embed/print-dialog.c @@ -1,5 +1,6 @@ /* * Copyright (C) 2002 Jorn Baayen + * Copyright (C) 2003 Christian Persch * * 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 @@ -19,53 +20,37 @@ */ #include "print-dialog.h" +#include "ephy-embed-dialog.h" +#include "ephy-file-chooser.h" +#include "eel-gconf-extensions.h" +#include "ephy-debug.h" -#include "ephy-command-manager.h" -#include "ephy-prefs.h" - -#include <gtk/gtktogglebutton.h> +#include <gtk/gtkwindow.h> #include <gtk/gtkdialog.h> +#include <gtk/gtkentry.h> #include <gtk/gtkstock.h> #include <libgnomevfs/gnome-vfs-utils.h> - -#define CONF_PRINT_BOTTOM_MARGIN "/apps/epiphany/dialogs/print_bottom_margin" -#define CONF_PRINT_TOP_MARGIN "/apps/epiphany/dialogs/print_top_margin" -#define CONF_PRINT_LEFT_MARGIN "/apps/epiphany/dialogs/print_left_margin" -#define CONF_PRINT_RIGHT_MARGIN "/apps/epiphany/dialogs/print_right_margin" -#define CONF_PRINT_PAGE_TITLE "/apps/epiphany/dialogs/print_page_title" -#define CONF_PRINT_PAGE_URL "/apps/epiphany/dialogs/print_page_url" -#define CONF_PRINT_DATE "/apps/epiphany/dialogs/print_date" -#define CONF_PRINT_PAGE_NUMBERS "/apps/epiphany/dialogs/print_page_numbers" -#define CONF_PRINT_PRINTER "/apps/epiphany/dialogs/print_printer" -#define CONF_PRINT_FILE "/apps/epiphany/dialogs/print_file" -#define CONF_PRINT_PRINTON "/apps/epiphany/dialogs/print_on" -#define CONF_PRINT_PAPER "/apps/epiphany/dialogs/print_paper" -#define CONF_PRINT_ALL_PAGES "/apps/epiphany/dialogs/print_all_pages" -#define CONF_PRINT_COLOR "/apps/epiphany/dialogs/print_color" -#define CONF_PRINT_ORIENTATION "/apps/epiphany/dialogs/print_orientation" - -static void print_dialog_class_init (PrintDialogClass *klass); -static void print_dialog_init (PrintDialog *dialog); - -/* Glade callbacks */ -void -print_cancel_button_cb (GtkWidget *widget, - EphyDialog *dialog); -void -print_ok_button_cb (GtkWidget *widget, - EphyDialog *dialog); -void -print_preview_button_cb (GtkWidget *widget, - EphyDialog *dialog); - -static GObjectClass *parent_class = NULL; - -#define EPHY_PRINT_DIALOG_GET_PRIVATE(object)(G_TYPE_INSTANCE_GET_PRIVATE ((object), EPHY_TYPE_PRINT_DIALOG, PrintDialogPrivate)) - -struct PrintDialogPrivate -{ - GtkWidget *window; -}; +#include <glib/gi18n.h> + +#define CONF_PRINT_PRINTER "/apps/epiphany/dialogs/print_printer" +#define CONF_PRINT_FILE "/apps/epiphany/dialogs/print_file" +#define CONF_PRINT_DIR "/apps/epiphany/directories/print_to_file" +#define CONF_PRINT_PRINTON "/apps/epiphany/dialogs/print_on" +#define CONF_PRINT_ALL_PAGES "/apps/epiphany/dialogs/print_all_pages" +#define CONF_PRINT_FROM_PAGE "/apps/epiphany/dialogs/print_from_page" +#define CONF_PRINT_TO_PAGE "/apps/epiphany/dialogs/print_to_page" + +#define CONF_PRINT_BOTTOM_MARGIN "/apps/epiphany/dialogs/print_bottom_margin" +#define CONF_PRINT_TOP_MARGIN "/apps/epiphany/dialogs/print_top_margin" +#define CONF_PRINT_LEFT_MARGIN "/apps/epiphany/dialogs/print_left_margin" +#define CONF_PRINT_RIGHT_MARGIN "/apps/epiphany/dialogs/print_right_margin" +#define CONF_PRINT_PAGE_TITLE "/apps/epiphany/dialogs/print_page_title" +#define CONF_PRINT_PAGE_URL "/apps/epiphany/dialogs/print_page_url" +#define CONF_PRINT_DATE "/apps/epiphany/dialogs/print_date" +#define CONF_PRINT_PAGE_NUMBERS "/apps/epiphany/dialogs/print_page_numbers" +#define CONF_PRINT_PAPER "/apps/epiphany/dialogs/print_paper" +#define CONF_PRINT_COLOR "/apps/epiphany/dialogs/print_color" +#define CONF_PRINT_ORIENTATION "/apps/epiphany/dialogs/print_orientation" enum { @@ -73,6 +58,30 @@ enum PRINTON_PROP, PRINTER_PROP, FILE_PROP, + ALL_PAGES_PROP, + SELECTION_PROP, + TO_PROP, + FROM_PROP +}; + +static const +EphyDialogProperty print_props [] = +{ + { "print_dialog", NULL, PT_NORMAL, 0 }, + { "printer_radiobutton", CONF_PRINT_PRINTON, PT_AUTOAPPLY, 0 }, + { "printer_entry", CONF_PRINT_PRINTER, PT_AUTOAPPLY, 0 }, + { "file_entry", CONF_PRINT_FILE, PT_AUTOAPPLY, 0 }, + { "all_pages_radiobutton", CONF_PRINT_ALL_PAGES, PT_AUTOAPPLY, 0 }, + { "selection_radiobutton", NULL, PT_NORMAL, 0 }, + { "to_spinbutton", CONF_PRINT_FROM_PAGE, PT_AUTOAPPLY, G_TYPE_INT }, + { "from_spinbutton", CONF_PRINT_TO_PAGE, PT_AUTOAPPLY, G_TYPE_INT }, + + { NULL } +}; + +enum +{ + SETUP_WINDOW_PROP, PAPER_PROP, TOP_PROP, BOTTOM_PROP, @@ -82,44 +91,25 @@ enum PAGE_URL_PROP, PAGE_NUMBERS_PROP, DATE_PROP, - ALL_PAGES_PROP, - TO_PROP, - FROM_PROP, COLOR_PROP, ORIENTATION_PROP, - PREVIEW_PROP, - SELECTION_PROP -}; - -enum -{ - PREVIEW, - LAST_SIGNAL }; static const -EphyDialogProperty properties [] = +EphyDialogProperty setup_props [] = { - { "print_dialog", NULL, PT_NORMAL, 0 }, - { "printer_radiobutton", CONF_PRINT_PRINTON, PT_NORMAL, 0 }, - { "printer_entry", CONF_PRINT_PRINTER, PT_NORMAL, 0 }, - { "file_entry", CONF_PRINT_FILE, PT_NORMAL, 0 }, - { "A4_radiobutton", CONF_PRINT_PAPER, PT_NORMAL, G_TYPE_STRING }, - { "top_spinbutton", CONF_PRINT_TOP_MARGIN, PT_NORMAL, 0 }, - { "bottom_spinbutton", CONF_PRINT_BOTTOM_MARGIN, PT_NORMAL, 0 }, - { "left_spinbutton", CONF_PRINT_LEFT_MARGIN, PT_NORMAL, 0 }, - { "right_spinbutton", CONF_PRINT_RIGHT_MARGIN, PT_NORMAL, 0 }, - { "print_page_title_checkbutton", CONF_PRINT_PAGE_TITLE, PT_NORMAL, 0 }, - { "print_page_url_checkbutton", CONF_PRINT_PAGE_URL, PT_NORMAL, 0 }, - { "print_page_numbers_checkbutton", CONF_PRINT_PAGE_NUMBERS, PT_NORMAL, 0 }, - { "print_date_checkbutton", CONF_PRINT_DATE, PT_NORMAL, 0 }, - { "all_pages_radiobutton", CONF_PRINT_ALL_PAGES, PT_NORMAL, 0 }, - { "to_spinbutton", NULL, PT_NORMAL, 0 }, - { "from_spinbutton", NULL, PT_NORMAL, 0 }, - { "print_color_radiobutton", CONF_PRINT_COLOR, PT_NORMAL, 0 }, - { "orient_p_radiobutton", CONF_PRINT_ORIENTATION, PT_NORMAL, 0 }, - { "preview_button", NULL, PT_NORMAL, 0 }, - { "selection_radiobutton", NULL, PT_NORMAL, 0 }, + { "print_setup_dialog", NULL, PT_NORMAL, 0 }, + { "A4_radiobutton", CONF_PRINT_PAPER, PT_AUTOAPPLY, G_TYPE_STRING }, + { "top_spinbutton", CONF_PRINT_TOP_MARGIN, PT_AUTOAPPLY, G_TYPE_INT }, + { "bottom_spinbutton", CONF_PRINT_BOTTOM_MARGIN, PT_AUTOAPPLY, G_TYPE_INT }, + { "left_spinbutton", CONF_PRINT_LEFT_MARGIN, PT_AUTOAPPLY, G_TYPE_INT }, + { "right_spinbutton", CONF_PRINT_RIGHT_MARGIN, PT_AUTOAPPLY, G_TYPE_INT }, + { "print_page_title_checkbutton", CONF_PRINT_PAGE_TITLE, PT_AUTOAPPLY, 0 }, + { "print_page_url_checkbutton", CONF_PRINT_PAGE_URL, PT_AUTOAPPLY, 0 }, + { "print_page_numbers_checkbutton", CONF_PRINT_PAGE_NUMBERS, PT_AUTOAPPLY, 0 }, + { "print_date_checkbutton", CONF_PRINT_DATE, PT_AUTOAPPLY, 0 }, + { "print_color_radiobutton", CONF_PRINT_COLOR, PT_AUTOAPPLY, 0 }, + { "orient_p_radiobutton", CONF_PRINT_ORIENTATION, PT_AUTOAPPLY, 0 }, { NULL } }; @@ -131,169 +121,19 @@ char *paper_format_enum [] = }; static guint n_paper_format_enum = G_N_ELEMENTS (paper_format_enum); -static guint print_dialog_signals[LAST_SIGNAL] = { 0 }; - -GType -print_dialog_get_type (void) -{ - static GType print_dialog_type = 0; - - if (print_dialog_type == 0) - { - static const GTypeInfo our_info = - { - sizeof (PrintDialogClass), - NULL, /* base_init */ - NULL, /* base_finalize */ - (GClassInitFunc) print_dialog_class_init, - NULL, - NULL, /* class_data */ - sizeof (PrintDialog), - 0, /* n_preallocs */ - (GInstanceInitFunc) print_dialog_init - }; - - print_dialog_type = g_type_register_static (EPHY_TYPE_EMBED_DIALOG, - "PrintDialog", - &our_info, 0); - } - - return print_dialog_type; - -} - -static void -impl_show (EphyDialog *dialog) -{ - PrintDialog *print_dialog = EPHY_PRINT_DIALOG (dialog); - EphyEmbed *embed = ephy_embed_dialog_get_embed (EPHY_EMBED_DIALOG (dialog)); - - EPHY_DIALOG_CLASS (parent_class)->show (dialog); - - if (print_dialog->only_collect_info) - { - GtkWidget *button; - - /* disappear preview button */ - button = ephy_dialog_get_control (EPHY_DIALOG (dialog), - properties[PREVIEW_PROP].id); - gtk_widget_hide (button); - } - - if (ephy_command_manager_can_do_command - (EPHY_COMMAND_MANAGER (embed), "cmd_copy") == FALSE) - { - GtkWidget *widget; - - /* Make selection button disabled */ - widget = ephy_dialog_get_control (EPHY_DIALOG (dialog), - properties[SELECTION_PROP].id); - - gtk_widget_set_sensitive (widget, FALSE); - - if (gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON (widget))) - { - GtkWidget *all_pages; - all_pages = ephy_dialog_get_control (EPHY_DIALOG (dialog), - properties[ALL_PAGES_PROP].id); - gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (all_pages), TRUE); - } - } -} - -static void -print_dialog_class_init (PrintDialogClass *klass) -{ - GObjectClass *object_class = G_OBJECT_CLASS (klass); - EphyDialogClass *dialog_class = EPHY_DIALOG_CLASS (klass); - - parent_class = g_type_class_peek_parent (klass); - - dialog_class->show = impl_show; - - print_dialog_signals[PREVIEW] = - g_signal_new ("preview", - G_OBJECT_CLASS_TYPE (object_class), - G_SIGNAL_RUN_FIRST, - G_STRUCT_OFFSET (PrintDialogClass, preview), - NULL, NULL, - g_cclosure_marshal_VOID__VOID, - G_TYPE_NONE, - 0); - - g_type_class_add_private (object_class, sizeof(PrintDialogPrivate)); -} - -static void -print_dialog_init (PrintDialog *dialog) -{ - GdkPixbuf *icon; - dialog->priv = EPHY_PRINT_DIALOG_GET_PRIVATE (dialog); - - dialog->only_collect_info = FALSE; - dialog->ret_info = NULL; - - ephy_dialog_construct (EPHY_DIALOG(dialog), - properties, - "print.glade", "print_dialog"); - - dialog->priv->window = ephy_dialog_get_control (EPHY_DIALOG(dialog), - properties[WINDOW_PROP].id); - - ephy_dialog_add_enum (EPHY_DIALOG (dialog), properties[PAPER_PROP].id, - n_paper_format_enum, paper_format_enum); - - icon = gtk_widget_render_icon (dialog->priv->window, - GTK_STOCK_PRINT, - GTK_ICON_SIZE_MENU, - "print_dialog"); - gtk_window_set_icon (GTK_WINDOW(dialog->priv->window), icon); - g_object_unref (icon); -} - -EphyDialog * -print_dialog_new (EphyEmbed *embed, - EmbedPrintInfo **ret_info) -{ - PrintDialog *dialog; - - dialog = EPHY_PRINT_DIALOG (g_object_new (EPHY_TYPE_PRINT_DIALOG, - "embed", embed, - NULL)); - - if (ret_info != NULL) - { - dialog->only_collect_info = TRUE; - dialog->ret_info = ret_info; - } - - return EPHY_DIALOG(dialog); -} - -EphyDialog * -print_dialog_new_with_parent (GtkWidget *window, - EphyEmbed *embed, - EmbedPrintInfo **ret_info) -{ - PrintDialog *dialog; - - dialog = EPHY_PRINT_DIALOG (g_object_new (EPHY_TYPE_PRINT_DIALOG, - "embed", embed, - "parent-window", window, - NULL)); - - if (ret_info != NULL) - { - dialog->only_collect_info = TRUE; - dialog->ret_info = ret_info; - } - - return EPHY_DIALOG(dialog); -} +void ephy_print_dialog_response_cb (GtkWidget *widget, + int response, + EphyDialog *dialog); +void ephy_print_dialog_browse_button_cb (GtkWidget *widget, + EphyDialog *dialog); +void ephy_print_setup_dialog_close_button_cb (GtkWidget *widget, + EphyDialog *dialog); void -print_free_info (EmbedPrintInfo *info) +ephy_print_info_free (EmbedPrintInfo *info) { + g_return_if_fail (info != NULL); + g_free (info->printer); g_free (info->file); g_free (info->paper); @@ -306,196 +146,208 @@ print_free_info (EmbedPrintInfo *info) g_free (info); } -static EmbedPrintInfo * -print_get_info (EphyDialog *dialog) +EmbedPrintInfo * +ephy_print_get_print_info (void) { EmbedPrintInfo *info; - GValue print_to_file = {0, }; - GValue printer = {0, }; - GValue file = {0, }; - GValue top_margin = {0, }; - GValue bottom_margin = {0, }; - GValue left_margin = {0, }; - GValue right_margin = {0, }; - GValue from_page = {0, }; - GValue to_page = {0, }; - GValue paper = {0, }; - GValue pages = {0, }; - GValue print_color = {0, }; - GValue orientation = {0, }; - GValue page_title = {0, }; - GValue page_url = {0, }; - GValue date = {0, }; - GValue page_numbers = {0, }; - const char *filename; + char *filename; info = g_new0 (EmbedPrintInfo, 1); - ephy_dialog_get_value (dialog, properties[PRINTON_PROP].id, &print_to_file); - info->print_to_file = g_value_get_int (&print_to_file); - g_value_unset (&print_to_file); - - ephy_dialog_get_value (dialog, properties[PRINTER_PROP].id, &printer); - info->printer = g_strdup (g_value_get_string (&printer)); - g_value_unset (&printer); - - ephy_dialog_get_value (dialog, properties[FILE_PROP].id, &file); - filename = g_value_get_string (&file); + filename = eel_gconf_get_string (print_props[FILE_PROP].pref); if (filename != NULL) { - info->file = gnome_vfs_expand_initial_tilde (g_value_get_string (&file)); + char *expanded; + + expanded = gnome_vfs_expand_initial_tilde (filename); + info->file = g_filename_to_utf8 (expanded, -1, NULL, NULL, NULL); } else { info->file = NULL; } - g_value_unset (&file); - - ephy_dialog_get_value (dialog, properties[BOTTOM_PROP].id, &bottom_margin); - info->bottom_margin = g_value_get_float (&bottom_margin); - g_value_unset (&bottom_margin); - - ephy_dialog_get_value (dialog, properties[LEFT_PROP].id, &left_margin); - info->left_margin = g_value_get_float (&left_margin); - g_value_unset (&left_margin); - - ephy_dialog_get_value (dialog, properties[TOP_PROP].id, &top_margin); - info->top_margin = g_value_get_float (&top_margin); - g_value_unset (&top_margin); + g_free (filename); - ephy_dialog_get_value (dialog, properties[RIGHT_PROP].id, &right_margin); - info->right_margin = g_value_get_float (&right_margin); - g_value_unset (&right_margin); + info->print_to_file = eel_gconf_get_integer (print_props[PRINTON_PROP].pref) == 1; + info->printer = eel_gconf_get_string (print_props[PRINTER_PROP].pref); - ephy_dialog_get_value (dialog, properties[FROM_PROP].id, &from_page); - info->from_page = g_value_get_float (&from_page); - g_value_unset (&from_page); + info->pages = eel_gconf_get_integer (print_props[ALL_PAGES_PROP].pref); + info->from_page = eel_gconf_get_integer (print_props[FROM_PROP].pref); + info->to_page = eel_gconf_get_integer (print_props[TO_PROP].pref); - ephy_dialog_get_value (dialog, properties[TO_PROP].id, &to_page); - info->to_page = g_value_get_float (&to_page); - g_value_unset (&to_page); + info->paper = eel_gconf_get_string (setup_props[PAPER_PROP].pref); + info->orientation = eel_gconf_get_integer (setup_props[ORIENTATION_PROP].pref); + info->print_color = ! eel_gconf_get_integer (setup_props[COLOR_PROP].pref); - ephy_dialog_get_value (dialog, properties[PAPER_PROP].id, &paper); - info->paper = g_strdup (paper_format_enum[g_value_get_int (&paper)]); - g_value_unset (&paper); - - ephy_dialog_get_value (dialog, properties[ALL_PAGES_PROP].id, &pages); - info->pages = g_value_get_int (&pages); - g_value_unset (&pages); - - ephy_dialog_get_value (dialog, properties[COLOR_PROP].id, &print_color); - info->print_color = !g_value_get_int (&print_color); - g_value_unset (&print_color); - - ephy_dialog_get_value (dialog, properties[ORIENTATION_PROP].id, &orientation); - info->orientation = g_value_get_int (&orientation); - g_value_unset (&orientation); - - info->frame_type = 0; + info->bottom_margin = eel_gconf_get_integer (setup_props[BOTTOM_PROP].pref); + info->top_margin = eel_gconf_get_integer (setup_props[TOP_PROP].pref); + info->left_margin = eel_gconf_get_integer (setup_props[LEFT_PROP].pref); + info->right_margin = eel_gconf_get_integer (setup_props[RIGHT_PROP].pref); - ephy_dialog_get_value (dialog, properties[PAGE_TITLE_PROP].id, &page_title); - info->header_left_string = g_value_get_boolean (&page_title) ? + info->header_left_string = eel_gconf_get_boolean (setup_props[PAGE_TITLE_PROP].pref) ? g_strdup ("&T") : g_strdup (""); - g_value_unset (&page_title); - - ephy_dialog_get_value (dialog, properties[PAGE_URL_PROP].id, &page_url); - info->header_right_string = g_value_get_boolean (&page_url) ? + info->header_right_string = eel_gconf_get_boolean (setup_props[PAGE_URL_PROP].pref) ? g_strdup ("&U") : g_strdup (""); - g_value_unset (&page_url); - - ephy_dialog_get_value (dialog, properties[PAGE_NUMBERS_PROP].id, &page_numbers); - info->footer_left_string = g_value_get_boolean (&page_numbers) ? + info->footer_left_string = eel_gconf_get_boolean (setup_props[PAGE_NUMBERS_PROP].pref) ? g_strdup ("&PT") : g_strdup (""); - g_value_unset (&page_numbers); - - ephy_dialog_get_value (dialog, properties[DATE_PROP].id, &date); - info->footer_right_string = g_value_get_boolean (&date) ? + info->footer_right_string = eel_gconf_get_boolean (setup_props[DATE_PROP].pref) ? g_strdup ("&D") : g_strdup (""); - g_value_unset (&date); - info->header_center_string = g_strdup(""); info->footer_center_string = g_strdup(""); + info->frame_type = 0; + info->preview = FALSE; + return info; } -static void -print_dialog_print (EphyDialog *dialog) +void +ephy_print_dialog_response_cb (GtkWidget *widget, + int response, + EphyDialog *dialog) { - EmbedPrintInfo *info; EphyEmbed *embed; + EmbedPrintInfo *info; + gboolean only_collect_info; - info = print_get_info (dialog); + only_collect_info = GPOINTER_TO_INT + (g_object_get_data (G_OBJECT (dialog), "only-collect-info")); - if(EPHY_PRINT_DIALOG(dialog)->only_collect_info && EPHY_PRINT_DIALOG(dialog)->ret_info) + if (only_collect_info) { - *(EPHY_PRINT_DIALOG(dialog)->ret_info) = info; - - /* When in collect_info mode the caller owns the reference */ return; } - embed = ephy_embed_dialog_get_embed - (EPHY_EMBED_DIALOG(dialog)); - g_return_if_fail (embed != NULL); - - info->preview = FALSE; - ephy_embed_print (embed, info); - print_free_info (info); + if (response == GTK_RESPONSE_OK) + { + info = ephy_print_get_print_info (); + + embed = ephy_embed_dialog_get_embed (EPHY_EMBED_DIALOG (dialog)); + g_return_if_fail (EPHY_IS_EMBED (embed)); + + ephy_embed_print (embed, info); + + ephy_print_info_free (info); + } - g_object_unref (G_OBJECT(dialog)); + g_object_unref (dialog); } static void -print_dialog_preview (EphyDialog *dialog) +print_filechooser_response_cb (GtkDialog *fc, + int response, + EphyDialog *dialog) { - EmbedPrintInfo *info; - EphyEmbed *embed; - - /* Should not be called in collect_info mode */ - if(EPHY_PRINT_DIALOG(dialog)->only_collect_info && EPHY_PRINT_DIALOG(dialog)->ret_info) + if (response == EPHY_RESPONSE_SAVE) { - g_return_if_reached (); - } + char *filename; - info = print_get_info (dialog); + filename = gtk_file_chooser_get_filename (GTK_FILE_CHOOSER (fc)); + if (filename != NULL) + { + GtkWidget *entry; + char *converted; - embed = ephy_embed_dialog_get_embed - (EPHY_EMBED_DIALOG(dialog)); - g_return_if_fail (embed != NULL); + converted = g_filename_to_utf8 (filename, -1, NULL, NULL, NULL); - info->preview = TRUE; - ephy_embed_print (embed, info); - print_free_info (info); + entry = ephy_dialog_get_control (dialog, print_props[FILE_PROP].id); + gtk_entry_set_text (GTK_ENTRY (entry), converted); - g_signal_emit (G_OBJECT (dialog), print_dialog_signals[PREVIEW], 0); + g_free (converted); + g_free (filename); + } + } - g_object_unref (G_OBJECT(dialog)); + gtk_widget_destroy (GTK_WIDGET (fc)); } void -print_cancel_button_cb (GtkWidget *widget, - EphyDialog *dialog) +ephy_print_dialog_browse_button_cb (GtkWidget *widget, + EphyDialog *dialog) { - if (EPHY_PRINT_DIALOG (dialog)->only_collect_info) - { - /* When in collect_info mode the caller owns the reference */ - return; - } + GtkWidget *parent; + EphyFileChooser *fc; + + parent = ephy_dialog_get_control (dialog, print_props[WINDOW_PROP].id); - g_object_unref (G_OBJECT(dialog)); + fc = ephy_file_chooser_new (_("Print to"), + GTK_WIDGET (parent), + GTK_FILE_CHOOSER_ACTION_SAVE, + CONF_PRINT_DIR); + + gtk_window_set_destroy_with_parent (GTK_WINDOW (fc), TRUE); + + g_signal_connect (GTK_DIALOG (fc), "response", + G_CALLBACK (print_filechooser_response_cb), + dialog); + + gtk_widget_show (GTK_WIDGET (fc)); } void -print_ok_button_cb (GtkWidget *widget, - EphyDialog *dialog) +ephy_print_setup_dialog_close_button_cb (GtkWidget *widget, + EphyDialog *dialog) { - print_dialog_print (dialog); + g_object_unref (dialog); } -void -print_preview_button_cb (GtkWidget *widget, - EphyDialog *dialog) +EphyDialog * +ephy_print_dialog_new (GtkWidget *parent, + EphyEmbed *embed, + gboolean only_collect_info) { - print_dialog_preview (dialog); + EphyDialog *dialog; + GtkWidget *window; + GdkPixbuf *icon; + + dialog = EPHY_DIALOG (g_object_new (EPHY_TYPE_EMBED_DIALOG, + "embed", embed, + NULL)); + + if (parent != NULL) + { + g_object_set (G_OBJECT (dialog), "parent-window", parent, NULL); + } + + ephy_dialog_construct (dialog, print_props, + "print.glade", "print_dialog"); + + window = ephy_dialog_get_control (dialog, print_props[WINDOW_PROP].id); + icon = gtk_widget_render_icon (window, + GTK_STOCK_PRINT, + GTK_ICON_SIZE_MENU, + "print_dialog"); + gtk_window_set_icon (GTK_WINDOW (window), icon); + g_object_unref (icon); + + g_object_set_data (G_OBJECT (dialog), "only-collect-info", + GINT_TO_POINTER (only_collect_info)); + + return dialog; +} + +EphyDialog * +ephy_print_setup_dialog_new (void) +{ + EphyDialog *dialog; + GtkWidget *window; + GdkPixbuf *icon; + + dialog = EPHY_DIALOG (g_object_new (EPHY_TYPE_DIALOG, NULL)); + + ephy_dialog_construct (dialog, setup_props, + "print.glade", "print_setup_dialog"); + + ephy_dialog_add_enum (dialog, setup_props[PAPER_PROP].id, + n_paper_format_enum, paper_format_enum); + + window = ephy_dialog_get_control (dialog, setup_props[SETUP_WINDOW_PROP].id); + icon = gtk_widget_render_icon (window, + GTK_STOCK_PROPERTIES, + GTK_ICON_SIZE_MENU, + "print_setup_dialog"); + gtk_window_set_icon (GTK_WINDOW (window), icon); + g_object_unref (icon); + + return dialog; } diff --git a/embed/print-dialog.h b/embed/print-dialog.h index 3ca150172..f7801d8f5 100644 --- a/embed/print-dialog.h +++ b/embed/print-dialog.h @@ -1,5 +1,6 @@ /* * Copyright (C) 2002 Jorn Baayen + * Copyright (C) 2003 Christian Persch * * 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 @@ -18,61 +19,28 @@ * $Id$ */ -#ifndef PRINT_DIALOG_H -#define PRINT_DIALOG_H +#ifndef EPHY_PRINT_DIALOG_H +#define EPHY_PRINT_DIALOG_H -#include "ephy-embed-dialog.h" +#include "ephy-dialog.h" #include "ephy-embed.h" #include <glib-object.h> #include <glib.h> +#include <gtk/gtkwidget.h> G_BEGIN_DECLS -#define EPHY_TYPE_PRINT_DIALOG (print_dialog_get_type ()) -#define EPHY_PRINT_DIALOG(o) (G_TYPE_CHECK_INSTANCE_CAST ((o), EPHY_TYPE_PRINT_DIALOG, PrintDialog)) -#define EPHY_PRINT_DIALOG_CLASS(k) (G_TYPE_CHECK_CLASS_CAST((k), EPHY_TYPE_PRINT_DIALOG, PrintDialogClass)) -#define EPHY_IS_PRINT_DIALOG(o) (G_TYPE_CHECK_INSTANCE_TYPE ((o), EPHY_TYPE_PRINT_DIALOG)) -#define EPHY_IS_PRINT_DIALOG_CLASS(k) (G_TYPE_CHECK_CLASS_TYPE ((k), EPHY_TYPE_PRINT_DIALOG)) -#define EPHY_PRINT_DIALOG_GET_CLASS(o) (G_TYPE_INSTANCE_GET_CLASS ((o), EPHY_TYPE_PRINT_DIALOG, PrintDialogClass)) - -typedef struct PrintDialog PrintDialog; -typedef struct PrintDialogClass PrintDialogClass; -typedef struct PrintDialogPrivate PrintDialogPrivate; - -struct PrintDialog -{ - EphyEmbedDialog parent; - - /*< private >*/ - PrintDialogPrivate *priv; - - //FIXME: These should be gobject properties - gboolean only_collect_info; - EmbedPrintInfo **ret_info; -}; - -struct PrintDialogClass -{ - EphyEmbedDialogClass parent_class; - - void (* preview) (PrintDialog *dialog); -}; - -GType print_dialog_get_type (void); - -EphyDialog *print_dialog_new (EphyEmbed *embed, - EmbedPrintInfo **ret_info); - -EphyDialog *print_dialog_new_with_parent (GtkWidget *window, +EphyDialog *ephy_print_dialog_new (GtkWidget *parent, EphyEmbed *embed, - EmbedPrintInfo **ret_info); + gboolean only_collect_info); -gboolean print_dialog_is_preview (PrintDialog *dialog); +EphyDialog *ephy_print_setup_dialog_new (void); -void print_free_info (EmbedPrintInfo *info); +EmbedPrintInfo *ephy_print_get_print_info (void); + +void ephy_print_info_free (EmbedPrintInfo *info); G_END_DECLS #endif - |