/* -*- Mode: C; indent-tabs-mode: t; c-basic-offset: 8; tab-width: 8 -*- */
/* e-summary-callbacks.c
*
* Author:
* Iain Holmes <iain@helixcode.com>
*
* Copyright (C) 2000 Helix Code, 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, write to the
* Free Software Foundation, Inc., 59 Temple Place - Suite 330,
* Boston, MA 02111-1307, USA.
*/
#ifdef HAVE_CONFIG_H
#include <config.h>
#endif
#include <gnome.h>
#include <bonobo.h>
#include <liboaf/liboaf.h>
#include <glade/glade.h>
#include <e-summary-callbacks.h>
#include <gtkhtml/gtkhtml.h>
#include <e-util/e-html-utils.h>
#include "e-summary.h"
#include "Composer.h"
#define COMPOSER_IID "OAFIID:GNOME_Evolution_Mail_Composer"
typedef struct _PropertyData {
ESummary *esummary;
GnomePropertyBox *box;
GladeXML *xml;
} PropertyData;
/* HTML helper functions from mail/mail-config-gui.c */
static void
html_size_req (GtkWidget *widget,
GtkRequisition *requisition)
{
requisition->height = GTK_LAYOUT (widget)->height;
}
/* Returns a GtkHTML which is already inside a GtkScrolledWindow. If
* @white is TRUE, the GtkScrolledWindow will be inside a GtkFrame.
*/
static GtkWidget *
html_new (gboolean white)
{
GtkWidget *html, *scrolled, *frame;
GtkStyle *style;
html = gtk_html_new ();
GTK_LAYOUT (html)->height = 0;
gtk_signal_connect (GTK_OBJECT (html), "size_request",
GTK_SIGNAL_FUNC (html_size_req), NULL);
gtk_html_set_editable (GTK_HTML (html), FALSE);
style = gtk_rc_get_style (html);
if (style) {
gtk_html_set_default_background_color (GTK_HTML (html),
white ? &style->white:
&style->bg[0]);
}
gtk_widget_set_sensitive (html, FALSE);
scrolled = gtk_scrolled_window_new (NULL, NULL);
gtk_scrolled_window_set_policy (GTK_SCROLLED_WINDOW (scrolled),
GTK_POLICY_NEVER, GTK_POLICY_NEVER);
gtk_container_add (GTK_CONTAINER (scrolled), html);
if (white) {
frame = gtk_frame_new (NULL);
gtk_frame_set_shadow_type (GTK_FRAME (frame),
GTK_SHADOW_ETCHED_IN);
gtk_container_add (GTK_CONTAINER (frame), scrolled);
gtk_widget_show_all (frame);
} else {
gtk_widget_show_all (scrolled);
}
return html;
}
static void
put_html (GtkHTML *html,
const char *text)
{
GtkHTMLStream *handle;
char *htmltext;
htmltext = e_text_to_html (text, E_TEXT_TO_HTML_CONVERT_NL);
handle = gtk_html_begin (html);
gtk_html_write (html, handle, "<HTML><BODY>", 12);
gtk_html_write (html, handle, text, strlen (text));
gtk_html_write (html, handle, "</BODY></HTML>", 14);
g_free (htmltext);
gtk_html_end (html, handle, GTK_HTML_STREAM_OK);
}
void
embed_service (GtkWidget *widget,
ESummary *esummary)
{
char *required_interfaces[2] = {"IDL:GNOME/Evolution:Summary:ComponentFactory:1.0",
NULL};
char *obj_id;
obj_id = bonobo_selector_select_id ("Select a service",
(const char **) required_interfaces);
if (obj_id == NULL)
return;
e_summary_embed_service_from_id (esummary, obj_id);
}
void
new_mail (GtkWidget *widget,
ESummary *esummary)
{
GNOME_Evolution_Composer_RecipientList *to, *cc, *bcc;
CORBA_char *subject;
CORBA_Object composer;
CORBA_Environment ev;
CORBA_exception_init (&ev);
composer = oaf_activate_from_id ((char *)COMPOSER_IID, 0, NULL, &ev);
if (ev._major != CORBA_NO_EXCEPTION || composer == NULL) {
CORBA_exception_free (&ev);
g_warning ("Unable to start composer component!");
return;
}
CORBA_exception_free (&ev);
to = GNOME_Evolution_Composer_RecipientList__alloc ();
to->_length = 0;
to->_maximum = 0;
to->_buffer = CORBA_sequence_GNOME_Evolution_Composer_Recipient_allocbuf (0);
cc = GNOME_Evolution_Composer_RecipientList__alloc ();
cc->_length = 0;
cc->_maximum = 0;
cc->_buffer = CORBA_sequence_GNOME_Evolution_Composer_Recipient_allocbuf (0);
bcc = GNOME_Evolution_Composer_RecipientList__alloc ();
bcc->_length = 0;
bcc->_maximum = 0;
bcc->_buffer = CORBA_sequence_GNOME_Evolution_Composer_Recipient_allocbuf (0);
subject = CORBA_string_dup ("");
CORBA_exception_init (&ev);
GNOME_Evolution_Composer_setHeaders (composer, to, cc,
bcc, subject, &ev);
if (ev._major != CORBA_NO_EXCEPTION) {
CORBA_exception_free (&ev);
CORBA_free (to);
CORBA_free (cc);
CORBA_free (bcc);
CORBA_free (subject);
g_warning ("Error setting headers!");
return;
}
CORBA_free (to);
CORBA_free (cc);
CORBA_free (bcc);
CORBA_free (subject);
GNOME_Evolution_Composer_show (composer, &ev);
if (ev._major != CORBA_NO_EXCEPTION) {
CORBA_exception_free (&ev);
g_warning ("Error showing composer");
return;
}
CORBA_exception_free (&ev);
return;
}
static void
destroy_prefs_cb (GtkObject *object,
PropertyData *data)
{
gtk_object_unref (GTK_OBJECT(data->xml));
g_free (data);
}
static void
html_page_changed_cb (GtkEntry *entry,
PropertyData *data)
{
ESummaryPrefs *prefs;
/* Change the tmp prefs so that we can restore if the user cancels */
prefs = data->esummary->tmp_prefs;
if (prefs->page)
g_free (prefs->page);
prefs->page = g_strdup (gtk_entry_get_text (entry));
gnome_property_box_changed (data->box);
}
static void
column_spinner_changed_cb (GtkEntry *entry,
PropertyData *data)
{
ESummaryPrefs *prefs;
char *value;
prefs = data->esummary->tmp_prefs;
gnome_property_box_changed (data->box);
value = gtk_entry_get_text (entry);
if (value == NULL || *value == '\0')
return;
prefs->columns = atoi (value);
}
static void
apply_prefs_cb (GnomePropertyBox *property_box,
int page,
ESummary *esummary)
{
g_print ("Applying\n");
if (page != -1)
return;
esummary->prefs = e_summary_prefs_copy (esummary->tmp_prefs);
e_summary_reconfigure (esummary);
}
void
configure_summary (GtkWidget *widget,
ESummary *esummary)
{
static GtkWidget *prefs = NULL;
PropertyData *data;
GtkWidget *html_page;
GtkWidget *vbox, *html, *spinner;
char *tmp;
if (prefs != NULL) {
g_assert (GTK_WIDGET_REALIZED (prefs));
gdk_window_show (prefs->window);
gdk_window_raise (prefs->window);
return;
}
data = g_new (PropertyData, 1);
data->esummary = esummary;
if (esummary->tmp_prefs != NULL) {
e_summary_prefs_free (esummary->tmp_prefs);
}
esummary->tmp_prefs = e_summary_prefs_copy (esummary->prefs);
data->xml = glade_xml_new (EVOLUTION_GLADEDIR
"/executive-summary-config.glade", NULL);
prefs = glade_xml_get_widget (data->xml, "summaryprefs");
data->box = GNOME_PROPERTY_BOX(prefs);
vbox = glade_xml_get_widget (data->xml, "vbox");
html = html_new (TRUE);
put_html (GTK_HTML(html),
_("You can select a different HTML page for the background "
"of the Executive Summary.\n\nJust leave it blank for the "
"default"));
gtk_box_pack_start (GTK_BOX (vbox), html->parent->parent, TRUE, TRUE, 0);
gtk_box_reorder_child (GTK_BOX (vbox), html->parent->parent, 0);
html_page = glade_xml_get_widget (data->xml, "htmlpage");
if (esummary->prefs->page != NULL)
gtk_entry_set_text (GTK_ENTRY (gnome_file_entry_gtk_entry (GNOME_FILE_ENTRY (html_page))), esummary->prefs->page);
gtk_signal_connect (GTK_OBJECT (gnome_file_entry_gtk_entry (GNOME_FILE_ENTRY (html_page))),
"changed", GTK_SIGNAL_FUNC (html_page_changed_cb),
data);
spinner = glade_xml_get_widget (data->xml, "columnspinner");
tmp = g_strdup_printf ("%d", esummary->prefs->columns);
gtk_entry_set_text (GTK_ENTRY (spinner), tmp);
g_free (tmp);
gtk_signal_connect (GTK_OBJECT (spinner), "changed",
GTK_SIGNAL_FUNC (column_spinner_changed_cb), data);
gtk_signal_connect (GTK_OBJECT (prefs), "apply",
GTK_SIGNAL_FUNC (apply_prefs_cb), esummary);
gtk_signal_connect (GTK_OBJECT (prefs), "destroy",
GTK_SIGNAL_FUNC (destroy_prefs_cb), data);
gtk_signal_connect (GTK_OBJECT (prefs), "destroy",
GTK_SIGNAL_FUNC (gtk_widget_destroyed), &prefs);
}