aboutsummaryrefslogtreecommitdiffstats
path: root/mail/mail-account-editor-news.c
blob: 1c980a9d6d9fea6a8dba3dd8b745fe26a69368e9 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
/* -*- Mode: C; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 8 -*- */
/*
 *  Cloned from mail-account-editor by Sam Creasey <sammy@oh.verio.com> 
 *
 *  Authors:
 *    Jeffrey Stedfast <fejj@ximian.com>
 *    Dan Winship <danw@ximian.com>
 *
 *  Copyright 2001 Ximian, Inc. (www.ximian.com)
 *
 *  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 Street #330, Boston, MA 02111-1307, USA.
 *
 */

#ifdef HAVE_CONFIG_H
#include <config.h>
#endif

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <libgnomeui/gnome-messagebox.h>
#include <libgnomeui/gnome-stock.h>
#include <camel/camel-url.h>
#include <gal/widgets/e-unicode.h>
#include <gal/widgets/e-gui-utils.h>

#include "mail-account-editor-news.h"
#include "mail-session.h"

static void mail_account_editor_news_class_init (MailAccountEditorNewsClass *class);
static void mail_account_editor_news_finalize   (GtkObject *obj);

static GnomeDialogClass *parent_class;


GtkType
mail_account_editor_news_get_type ()
{
    static GtkType type = 0;

    if (!type) {
        GtkTypeInfo type_info = {
            "MailAccountEditorNews",
            sizeof (MailAccountEditorNews),
            sizeof (MailAccountEditorNewsClass),
            (GtkClassInitFunc) mail_account_editor_news_class_init,
            (GtkObjectInitFunc) NULL,
            (GtkArgSetFunc) NULL,
            (GtkArgGetFunc) NULL
        };

        type = gtk_type_unique (gnome_dialog_get_type (), &type_info);
    }

    return type;
}

static void
mail_account_editor_news_class_init (MailAccountEditorNewsClass *class)
{
    GtkObjectClass *object_class;

    object_class = (GtkObjectClass *) class;
    parent_class = gtk_type_class (gnome_dialog_get_type ());

    object_class->finalize = mail_account_editor_news_finalize;
}

static void
mail_account_editor_news_finalize (GtkObject *obj)
{
    MailAccountEditorNews *editor = (MailAccountEditorNews *) obj;

    gtk_object_unref (GTK_OBJECT (editor->xml));

        ((GtkObjectClass *)(parent_class))->finalize (obj);
}

static gboolean
apply_changes(MailAccountEditorNews *editor)
{
    
    CamelURL *url;
    GtkEntry *service_ent;
    
    service_ent = GTK_ENTRY(glade_xml_get_widget(editor->xml, "source_name"));
    url = g_new0 (CamelURL, 1);

    url->protocol = g_strdup("nntp");
    url->host = g_strdup(gtk_entry_get_text(service_ent));
    if(strlen(url->host) == 0) {
        e_notice (NULL, GNOME_MESSAGE_BOX_ERROR, _("You have not filled in all of the required information."));
        camel_url_free(url);
        return FALSE;
    }
    
    if(editor->service->url == NULL) 
        mail_config_add_news(editor->service);
    
    editor->service->url = camel_url_to_string(url, 0);
    
    mail_config_write();
    return TRUE;
}

static void
apply_clicked (GtkWidget *widget, gpointer data)
{
    MailAccountEditorNews *editor = data;

    apply_changes (editor);
}

static void
ok_clicked (GtkWidget *widget, gpointer data)
{
    MailAccountEditorNews *editor = data;

    if (apply_changes (editor))
        gtk_widget_destroy (GTK_WIDGET (editor));
}

static void
cancel_clicked (GtkWidget *widget, gpointer data)
{
    MailAccountEditorNews *editor = data;

    gtk_widget_destroy (GTK_WIDGET (editor));
}

MailAccountEditorNews *
mail_account_editor_news_new (MailConfigService *service)
{
    MailAccountEditorNews *editor;
    GtkEntry *service_ent;

    editor = (MailAccountEditorNews *) gtk_type_new (mail_account_editor_news_get_type ());

    editor->service = service;
    editor->xml = glade_xml_new (EVOLUTION_GLADEDIR "/mail-config.glade", NULL);

    /* get our toplevel widget and reparent it */
    editor->notebook = GTK_NOTEBOOK (glade_xml_get_widget (editor->xml, "news_editor_notebook"));
    gtk_widget_reparent (GTK_WIDGET (editor->notebook), GNOME_DIALOG (editor)->vbox);

    /* give our dialog an OK button and title */
    gtk_window_set_title (GTK_WINDOW (editor), _("Evolution News Editor"));
    gtk_window_set_policy (GTK_WINDOW (editor), FALSE, TRUE, TRUE);
    gtk_window_set_modal (GTK_WINDOW (editor), TRUE);
    gnome_dialog_append_buttons (GNOME_DIALOG (editor),
                     GNOME_STOCK_BUTTON_OK,
                     GNOME_STOCK_BUTTON_APPLY,
                     GNOME_STOCK_BUTTON_CANCEL,
                     NULL);

    gnome_dialog_button_connect (GNOME_DIALOG (editor), 0 /* OK */,
                     GTK_SIGNAL_FUNC (ok_clicked),
                     editor);
    gnome_dialog_button_connect (GNOME_DIALOG (editor), 1 /* APPLY */,
                     GTK_SIGNAL_FUNC (apply_clicked),
                     editor);
    gnome_dialog_button_connect (GNOME_DIALOG (editor), 2 /* CANCEL */,
                     GTK_SIGNAL_FUNC (cancel_clicked),
                     editor);

    if(service->url) {
        CamelURL *url;
        
        url = camel_url_new(service->url, NULL);
        
        if(url->host) {
            service_ent = GTK_ENTRY(glade_xml_get_widget(editor->xml, "source_name"));
            gtk_entry_set_text(service_ent, url->host);
        }
        
        camel_url_free(url);
    }
                                     
    return editor;
}
>+10 * Downgrade to 7.0.1 temporarily mainly because the printing featurehrs2006-03-082-5/+6 * Now buildable againkris2006-03-081-2/+0 * Bump PORTREVISION on glib12/gtk12 consumer ports to ease the upgrade path.ade2006-03-079-8/+9 * Run ldconfig(8) as a pre-command for vjed, to get the compat3xknu2006-03-072-3/+3 * Remove japanese/vje30-trial which is no longer distributed.knu2006-03-078-397/+0 * Update distinfo and bump PORTREVISION because the distfilehrs2006-03-072-5/+4 * Remove japanese/squirrelmail.nork2006-03-053-46/+0 * Update distinfo because the distfile has been replacedhrs2006-03-031-3/+3 * Only specify autoconf:213:env to fix package buildkris2006-02-281-1/+1 * Only specify autoconf:213:env to fix the package buildkris2006-02-281-1/+1 * BROKEN: Incomplete pkg-plistkris2006-02-262-0/+4 * Remove directory now owned by parentkris2006-02-261-1/+0 * Fix devel/libytnef[1] and others[2] after libtool commit.ade2006-02-243-3/+3 * Conversion to a single libtool environment.ade2006-02-2326-25/+49 * - Use a distfile in tarball instead of one in rpm.hrs2006-02-224-570/+5 * Fix pkg-plist.hrs2006-02-212-4/+4 * Remove the FreeBSD KEYWORD from all rc.d scripts where it appears.dougb2006-02-219-9/+8 * Bump PORTREVISION because of print/ghostscript-gnu-commfont update.hrs2006-02-211-1/+1 * - Fix RUN_DEPENDS.hrs2006-02-212-12/+12 * Chase net/samba3 upgrade.kuriyama2006-02-202-7/+7 * BROKEN: Incomplete pkg-plistkris2006-02-205-0/+10 * Try to remove www/datakris2006-02-202-0/+2 * Fix failure of anthy dictionary generation with TMPDIR environment variable.nobutaka2006-02-191-0/+11 * Fix a malformed entry in the fonts.alias file.hrs2006-02-152-17/+2 * BROKEN: Does not compilekris2006-02-131-0/+2 * BROKEN: Coredump during buildkris2006-02-131-0/+2 * - Set UNAME_s=Linux since FreeBSD's native uname(1) is invokedhrs2006-02-112-2/+4 * Update to 7.0.5.hrs2006-02-114-208/+277 * Update to 1.0.0.nork2006-02-113-25/+6 * * Remove print/acroread - it has expired on 2006-01-03vd2006-02-104-24/+0 * * Try to fix xemacs-devel japanese ports.anray2006-02-084-0/+4 * - Fix build with libtool 1.5.22_1barner2006-02-081-0/+10 * - Remove USE_REINPLACEbarner2006-02-062-7/+3 * Remove broken and expired ports japanese/gn-gnspool, www/adzap2squirmvs2006-02-0612-313/+0 * - Add a configuration file for fontconfig[*]hrs2006-02-066-4/+98 * Add MOTOYA Birch W1 font.nork2006-02-045-8/+78 * Update to 3.5pl3.nork2006-02-044-7/+44 * Add autoconf:213 to satisfy :configure targetkris2006-02-041-1/+1 * Add autoconf:213 dependency to allow :configure target to runkris2006-02-041-1/+1 * - Update to 1.5.0.1ahze2006-02-032-4/+4 * - Unbreak by fixing dependency to textproc/uimbarner2006-02-021-4/+2 * - Rename japanese/firefox-ja_JP to japanese/firefox-japav2006-02-015-87/+1 * Update to KDE 3.5.1.lofi2006-02-014-6/+50 * Patched version is not required for textproc/senna of recent version.kuriyama2006-01-315-67/+0 * Fix breakage with WITH_ADS knob.kuriyama2006-01-312-5/+5 * Fix unfetchable situation by putting distfile on my box.kuriyama2006-01-311-1/+2 * - Catch up Japanese patch to 0.9.3.kuriyama2006-01-302-5/+4 * SHA256ifyedwin2006-01-307-6/+20 * SHA256ifyedwin2006-01-307-2/+53 * Update to 0.9.0.ume2006-01-302-5/+5 * - Unbreakpav2006-01-3010-112/+66 * Previous commit was bogus.kris2006-01-301-2/+0 * Try to clean up two directories we might have createdkris2006-01-291-0/+2 * - Fix possibility of "infinite make fork" when "Registering install for ..."linimon2006-01-2821-0/+22 * Update dependencies to moved portmnag2006-01-281-2/+2 * The default security option has been changed in the Japanesehrs2006-01-262-4/+4 * - Unbreak with darts 0.3pav2006-01-262-4/+11 * BROKEN when WITHOUT_X11: Broken dependencykris2006-01-261-0/+4 * - Mark it as DEPRECATED - "mastersite disappeared, no longer maintained bygarga2006-01-251-1/+4 * SHA256ifyedwin2006-01-22