summaryrefslogtreecommitdiff
path: root/gtk/gtkprintoperation-unix.c
diff options
context:
space:
mode:
authorMarek Kasik <mkasik@redhat.com>2009-07-10 11:28:31 +0200
committerMarek Kasik <mkasik@redhat.com>2009-07-10 11:28:31 +0200
commit0ef74c936f7a5b36a66ea828506b4b44e25a1998 (patch)
treecd3492286b53633ee7f9dd8fa692287e1119c950 /gtk/gtkprintoperation-unix.c
parent6ca5430a74c86b448e96b64166d67b3268e24789 (diff)
downloadgtk+-0ef74c936f7a5b36a66ea828506b4b44e25a1998.tar.gz
Add paper size combo and orientation combo to print dialog
Paper size combo and orientation combo can be added by gtk_print_operation_set_embed_page_setup_dialog() to GtkPrinUnixDialog now. This function induce calling of gtk_print_unix_dailog_set_embed_page_setup_dialog() after creation of dialog. These two functions control embed-page-setup-dialog properties in GtkPrintOperation and in GtkPrintUnixDialog. There is also new function gtk_print_unix_dialog_get_page_setup_set() which says whether page setup was set by user. Selected page setup is stored as default page setup in GtkPrintOperation. New class is added, its name is GtkCustomPaperUnixDialog. The class manages custom sizes. It is derived from GtkPageSetupUnixDialog's CustomPaperDialog structure. Page layout preview is modified, so, it shows dimensions of current page setup (mm or inch - depends on locale). It also shows the name of actual paper if page setup dialog is not embedded (paper size combo is not visible). gtk-demo is actualized to include this new feature.
Diffstat (limited to 'gtk/gtkprintoperation-unix.c')
-rw-r--r--gtk/gtkprintoperation-unix.c17
1 files changed, 13 insertions, 4 deletions
diff --git a/gtk/gtkprintoperation-unix.c b/gtk/gtkprintoperation-unix.c
index 765752b158..c31f324acb 100644
--- a/gtk/gtkprintoperation-unix.c
+++ b/gtk/gtkprintoperation-unix.c
@@ -414,10 +414,14 @@ get_print_dialog (GtkPrintOperation *op,
if (priv->print_settings)
gtk_print_unix_dialog_set_settings (GTK_PRINT_UNIX_DIALOG (pd),
priv->print_settings);
+
if (priv->default_page_setup)
gtk_print_unix_dialog_set_page_setup (GTK_PRINT_UNIX_DIALOG (pd),
priv->default_page_setup);
+ gtk_print_unix_dialog_set_embed_page_setup (GTK_PRINT_UNIX_DIALOG (pd),
+ priv->embed_page_setup);
+
gtk_print_unix_dialog_set_current_page (GTK_PRINT_UNIX_DIALOG (pd),
priv->current_page);
@@ -477,7 +481,8 @@ static void
finish_print (PrintResponseData *rdata,
GtkPrinter *printer,
GtkPageSetup *page_setup,
- GtkPrintSettings *settings)
+ GtkPrintSettings *settings,
+ gboolean page_setup_set)
{
GtkPrintOperation *op = rdata->op;
GtkPrintOperationPrivate *priv = op->priv;
@@ -488,7 +493,9 @@ finish_print (PrintResponseData *rdata,
gtk_print_operation_set_print_settings (op, settings);
priv->print_context = _gtk_print_context_new (op);
- if ( (page_setup != NULL) && (gtk_print_operation_get_default_page_setup (op) == NULL))
+ if (page_setup != NULL &&
+ (gtk_print_operation_get_default_page_setup (op) == NULL ||
+ page_setup_set))
gtk_print_operation_set_default_page_setup (op, page_setup);
_gtk_print_context_set_page_setup (priv->print_context, page_setup);
@@ -561,6 +568,7 @@ handle_print_response (GtkWidget *dialog,
GtkPrintSettings *settings = NULL;
GtkPageSetup *page_setup = NULL;
GtkPrinter *printer = NULL;
+ gboolean page_setup_set = FALSE;
if (response == GTK_RESPONSE_OK)
{
@@ -585,11 +593,12 @@ handle_print_response (GtkWidget *dialog,
{
settings = gtk_print_unix_dialog_get_settings (GTK_PRINT_UNIX_DIALOG (pd));
page_setup = gtk_print_unix_dialog_get_page_setup (GTK_PRINT_UNIX_DIALOG (pd));
+ page_setup_set = gtk_print_unix_dialog_get_page_setup_set (GTK_PRINT_UNIX_DIALOG (pd));
g_signal_emit_by_name (rdata->op, "custom-widget-apply", rdata->op->priv->custom_widget);
}
- finish_print (rdata, printer, page_setup, settings);
+ finish_print (rdata, printer, page_setup, settings, page_setup_set);
if (settings)
g_object_unref (settings);
@@ -631,7 +640,7 @@ found_printer (GtkPrinter *printer,
page_setup = gtk_page_setup_new ();
}
- finish_print (rdata, printer, page_setup, settings);
+ finish_print (rdata, printer, page_setup, settings, FALSE);
if (settings)
g_object_unref (settings);