diff options
-rw-r--r-- | addressbook/ChangeLog | 31 | ||||
-rw-r--r-- | addressbook/gui/contact-editor/contact-editor.glade | 176 | ||||
-rw-r--r-- | addressbook/gui/contact-editor/e-contact-editor.c | 483 |
3 files changed, 310 insertions, 380 deletions
diff --git a/addressbook/ChangeLog b/addressbook/ChangeLog index e475823b38..e9c6deb499 100644 --- a/addressbook/ChangeLog +++ b/addressbook/ChangeLog @@ -1,3 +1,34 @@ +2004-04-21 Hans Petter Jansson <hpj@ximian.com> + + * gui/contact-editor/contact-editor.glade: Make the phone type + selectors be option menus. + + * gui/contact-editor/e-contact-editor.c (phones): Store the phone + param mappings locally. + (set_entry_changed_signals): Don't special-case phone entries here. + (enable_writable_fields): Don't mess with the phone widgets anymore. + (set_fields): Use fill_in_phone (). + (extract_info): Use extract_phone (). + (phone_index_to_type): Implement. + (get_phone_type): Implement. + (get_attributes_named): Implement. + (set_attributes_named): Implement. + (fill_in_phone_record): Implement. + (extract_phone_record): Implement. + (fill_in_phone): Implement. + (extract_phone): Implement. + (init_phone_record_type): Implement. + (init_phone): Implement. + (connect_arrow_button_signal): Remove. + (connect_arrow_button_signals): Remove. + (phone_entry_changed): Remove. + (set_entry_changed_signal_phone): Remove. + (_arrow_pressed): Remove. + (_phone_arrow_pressed): Remove. + (e_contact_editor_build_ui_info): Remove. + (e_contact_editor_build_phone_ui): Remove. + (set_phone_field): Remove. + 2004-04-21 Not Zed <NotZed@Ximian.com> * gui/component/addressbook-view.c (addressbook_view_init): fix diff --git a/addressbook/gui/contact-editor/contact-editor.glade b/addressbook/gui/contact-editor/contact-editor.glade index ceb32b2b67..43de540887 100644 --- a/addressbook/gui/contact-editor/contact-editor.glade +++ b/addressbook/gui/contact-editor/contact-editor.glade @@ -770,54 +770,30 @@ </child> <child> - <widget class="GtkButton" id="button-phone-1"> + <widget class="GtkOptionMenu" id="optionmenu-phone-1"> <property name="visible">True</property> <property name="can_focus">True</property> - <property name="relief">GTK_RELIEF_NORMAL</property> + <property name="history">0</property> <child> - <widget class="GtkHBox" id="hbox57"> - <property name="border_width">1</property> - <property name="visible">True</property> - <property name="homogeneous">False</property> - <property name="spacing">6</property> + <widget class="GtkMenu" id="menu179"> <child> - <widget class="GtkLabel" id="label-phone-1"> + <widget class="GtkMenuItem" id="menuitem412"> <property name="visible">True</property> - <property name="label" translatable="yes">_Business:</property> + <property name="label" translatable="yes">Work</property> <property name="use_underline">True</property> - <property name="use_markup">False</property> - <property name="justify">GTK_JUSTIFY_LEFT</property> - <property name="wrap">False</property> - <property name="selectable">False</property> - <property name="xalign">0</property> - <property name="yalign">0.5</property> - <property name="xpad">2</property> - <property name="ypad">0</property> + <signal name="activate" handler="on_work2_activate" last_modification_time="Fri, 12 Mar 2004 19:27:14 GMT"/> </widget> - <packing> - <property name="padding">0</property> - <property name="expand">True</property> - <property name="fill">True</property> - </packing> </child> <child> - <widget class="GtkArrow" id="arrow1"> + <widget class="GtkMenuItem" id="menuitem413"> <property name="visible">True</property> - <property name="arrow_type">GTK_ARROW_DOWN</property> - <property name="shadow_type">GTK_SHADOW_OUT</property> - <property name="xalign">0.5</property> - <property name="yalign">0.5</property> - <property name="xpad">0</property> - <property name="ypad">0</property> + <property name="label" translatable="yes">Personal</property> + <property name="use_underline">True</property> + <signal name="activate" handler="on_personal2_activate" last_modification_time="Fri, 12 Mar 2004 19:27:14 GMT"/> </widget> - <packing> - <property name="padding">0</property> - <property name="expand">False</property> - <property name="fill">True</property> - </packing> </child> </widget> </child> @@ -833,54 +809,30 @@ </child> <child> - <widget class="GtkButton" id="button-phone-2"> + <widget class="GtkOptionMenu" id="optionmenu-phone-2"> <property name="visible">True</property> <property name="can_focus">True</property> - <property name="relief">GTK_RELIEF_NORMAL</property> + <property name="history">0</property> <child> - <widget class="GtkHBox" id="hbox58"> - <property name="border_width">1</property> - <property name="visible">True</property> - <property name="homogeneous">False</property> - <property name="spacing">6</property> + <widget class="GtkMenu" id="menu180"> <child> - <widget class="GtkLabel" id="label-phone-2"> + <widget class="GtkMenuItem" id="menuitem414"> <property name="visible">True</property> - <property name="label" translatable="yes">_Home:</property> + <property name="label" translatable="yes">Work</property> <property name="use_underline">True</property> - <property name="use_markup">False</property> - <property name="justify">GTK_JUSTIFY_LEFT</property> - <property name="wrap">False</property> - <property name="selectable">False</property> - <property name="xalign">0</property> - <property name="yalign">0.5</property> - <property name="xpad">2</property> - <property name="ypad">0</property> + <signal name="activate" handler="on_work2_activate" last_modification_time="Fri, 12 Mar 2004 19:27:14 GMT"/> </widget> - <packing> - <property name="padding">0</property> - <property name="expand">True</property> - <property name="fill">True</property> - </packing> </child> <child> - <widget class="GtkArrow" id="arrow2"> + <widget class="GtkMenuItem" id="menuitem415"> <property name="visible">True</property> - <property name="arrow_type">GTK_ARROW_DOWN</property> - <property name="shadow_type">GTK_SHADOW_OUT</property> - <property name="xalign">0.5</property> - <property name="yalign">0.5</property> - <property name="xpad">0</property> - <property name="ypad">0</property> + <property name="label" translatable="yes">Personal</property> + <property name="use_underline">True</property> + <signal name="activate" handler="on_personal2_activate" last_modification_time="Fri, 12 Mar 2004 19:27:14 GMT"/> </widget> - <packing> - <property name="padding">0</property> - <property name="expand">False</property> - <property name="fill">True</property> - </packing> </child> </widget> </child> @@ -896,54 +848,30 @@ </child> <child> - <widget class="GtkButton" id="button-phone-3"> + <widget class="GtkOptionMenu" id="optionmenu-phone-3"> <property name="visible">True</property> <property name="can_focus">True</property> - <property name="relief">GTK_RELIEF_NORMAL</property> + <property name="history">0</property> <child> - <widget class="GtkHBox" id="hbox59"> - <property name="border_width">1</property> - <property name="visible">True</property> - <property name="homogeneous">False</property> - <property name="spacing">6</property> + <widget class="GtkMenu" id="menu181"> <child> - <widget class="GtkLabel" id="label-phone-3"> + <widget class="GtkMenuItem" id="menuitem416"> <property name="visible">True</property> - <property name="label" translatable="yes">Business _fax:</property> + <property name="label" translatable="yes">Work</property> <property name="use_underline">True</property> - <property name="use_markup">False</property> - <property name="justify">GTK_JUSTIFY_LEFT</property> - <property name="wrap">False</property> - <property name="selectable">False</property> - <property name="xalign">0</property> - <property name="yalign">0.5</property> - <property name="xpad">2</property> - <property name="ypad">0</property> + <signal name="activate" handler="on_work2_activate" last_modification_time="Fri, 12 Mar 2004 19:27:14 GMT"/> </widget> - <packing> - <property name="padding">0</property> - <property name="expand">True</property> - <property name="fill">True</property> - </packing> </child> <child> - <widget class="GtkArrow" id="arrow3"> + <widget class="GtkMenuItem" id="menuitem417"> <property name="visible">True</property> - <property name="arrow_type">GTK_ARROW_DOWN</property> - <property name="shadow_type">GTK_SHADOW_OUT</property> - <property name="xalign">0.5</property> - <property name="yalign">0.5</property> - <property name="xpad">0</property> - <property name="ypad">0</property> + <property name="label" translatable="yes">Personal</property> + <property name="use_underline">True</property> + <signal name="activate" handler="on_personal2_activate" last_modification_time="Fri, 12 Mar 2004 19:27:14 GMT"/> </widget> - <packing> - <property name="padding">0</property> - <property name="expand">False</property> - <property name="fill">True</property> - </packing> </child> </widget> </child> @@ -959,54 +887,30 @@ </child> <child> - <widget class="GtkButton" id="button-phone-4"> + <widget class="GtkOptionMenu" id="optionmenu-phone-4"> <property name="visible">True</property> <property name="can_focus">True</property> - <property name="relief">GTK_RELIEF_NORMAL</property> + <property name="history">0</property> <child> - <widget class="GtkHBox" id="hbox60"> - <property name="border_width">1</property> - <property name="visible">True</property> - <property name="homogeneous">False</property> - <property name="spacing">6</property> + <widget class="GtkMenu" id="menu182"> <child> - <widget class="GtkLabel" id="label-phone-4"> + <widget class="GtkMenuItem" id="menuitem418"> <property name="visible">True</property> - <property name="label" translatable="yes">_Mobile:</property> + <property name="label" translatable="yes">Work</property> <property name="use_underline">True</property> - <property name="use_markup">False</property> - <property name="justify">GTK_JUSTIFY_LEFT</property> - <property name="wrap">False</property> - <property name="selectable">False</property> - <property name="xalign">0</property> - <property name="yalign">0.5</property> - <property name="xpad">2</property> - <property name="ypad">0</property> + <signal name="activate" handler="on_work2_activate" last_modification_time="Fri, 12 Mar 2004 19:27:14 GMT"/> </widget> - <packing> - <property name="padding">0</property> - <property name="expand">True</property> - <property name="fill">True</property> - </packing> </child> <child> - <widget class="GtkArrow" id="arrow4"> + <widget class="GtkMenuItem" id="menuitem419"> <property name="visible">True</property> - <property name="arrow_type">GTK_ARROW_DOWN</property> - <property name="shadow_type">GTK_SHADOW_OUT</property> - <property name="xalign">0.5</property> - <property name="yalign">0.5</property> - <property name="xpad">0</property> - <property name="ypad">0</property> + <property name="label" translatable="yes">Personal</property> + <property name="use_underline">True</property> + <signal name="activate" handler="on_personal2_activate" last_modification_time="Fri, 12 Mar 2004 19:27:14 GMT"/> </widget> - <packing> - <property name="padding">0</property> - <property name="expand">False</property> - <property name="fill">True</property> - </packing> </child> </widget> </child> diff --git a/addressbook/gui/contact-editor/e-contact-editor.c b/addressbook/gui/contact-editor/e-contact-editor.c index 8b247751c6..b06269877a 100644 --- a/addressbook/gui/contact-editor/e-contact-editor.c +++ b/addressbook/gui/contact-editor/e-contact-editor.c @@ -93,13 +93,11 @@ static gboolean e_contact_editor_is_valid (EABEditor *editor); static gboolean e_contact_editor_is_changed (EABEditor *editor); static GtkWindow* e_contact_editor_get_window (EABEditor *editor); -static void _phone_arrow_pressed (GtkWidget *widget, GdkEventButton *button, EContactEditor *editor); static void enable_writable_fields(EContactEditor *editor); static void set_editable(EContactEditor *editor); static void fill_in_info(EContactEditor *editor); static void extract_info(EContactEditor *editor); static void set_entry_text(EContactEditor *editor, GtkEntry *entry, const char *string); -static void set_phone_field(EContactEditor *editor, GtkWidget *entry, const char *phone_number); static void set_fields(EContactEditor *editor); static void command_state_changed (EContactEditor *ce); static void widget_changed (GtkWidget *widget, EContactEditor *editor); @@ -125,26 +123,28 @@ enum { DYNAMIC_LIST_ADDRESS }; -static EContactField phones[] = { - E_CONTACT_PHONE_ASSISTANT, - E_CONTACT_PHONE_BUSINESS, - E_CONTACT_PHONE_BUSINESS_2, - E_CONTACT_PHONE_BUSINESS_FAX, - E_CONTACT_PHONE_CALLBACK, - E_CONTACT_PHONE_CAR, - E_CONTACT_PHONE_COMPANY, - E_CONTACT_PHONE_HOME, - E_CONTACT_PHONE_HOME_2, - E_CONTACT_PHONE_HOME_FAX, - E_CONTACT_PHONE_ISDN, - E_CONTACT_PHONE_MOBILE, - E_CONTACT_PHONE_OTHER, - E_CONTACT_PHONE_OTHER_FAX, - E_CONTACT_PHONE_PAGER, - E_CONTACT_PHONE_PRIMARY, - E_CONTACT_PHONE_RADIO, - E_CONTACT_PHONE_TELEX, - E_CONTACT_PHONE_TTYTDD, +static struct { + EContactField field_id; + const gchar *type_1; + const gchar *type_2; +} +phones [] = { + { E_CONTACT_PHONE_ASSISTANT, EVC_X_ASSISTANT, NULL }, + { E_CONTACT_PHONE_BUSINESS, "WORK", "VOICE" }, + { E_CONTACT_PHONE_BUSINESS_FAX, "WORK", "FAX" }, + { E_CONTACT_PHONE_CALLBACK, EVC_X_CALLBACK, NULL }, + { E_CONTACT_PHONE_CAR, "CAR", NULL }, + { E_CONTACT_PHONE_HOME, "HOME", "VOICE" }, + { E_CONTACT_PHONE_HOME_FAX, "HOME", "FAX" }, + { E_CONTACT_PHONE_ISDN, "ISDN", NULL }, + { E_CONTACT_PHONE_MOBILE, "CELL", NULL }, + { E_CONTACT_PHONE_OTHER, "VOICE", NULL }, + { E_CONTACT_PHONE_OTHER_FAX, "FAX", NULL }, + { E_CONTACT_PHONE_PAGER, "PAGER", NULL }, + { E_CONTACT_PHONE_PRIMARY, "PREF", NULL }, + { E_CONTACT_PHONE_RADIO, EVC_X_RADIO, NULL }, + { E_CONTACT_PHONE_TELEX, EVC_X_TELEX, NULL }, + { E_CONTACT_PHONE_TTYTDD, EVC_X_TTYTDD, NULL } }; static EContactField emails[] = { @@ -378,6 +378,13 @@ im_index_to_location (gint index) return im_location [index].name; } +static void +phone_index_to_type (gint index, const gchar **type_1, const gchar **type_2) +{ + *type_1 = phones [index].type_1; + *type_2 = phones [index].type_2; +} + static gint get_email_location (EVCardAttribute *attr) { @@ -404,6 +411,20 @@ get_im_location (EVCardAttribute *attr) return -1; } +static gint +get_phone_type (EVCardAttribute *attr) +{ + gint i; + + for (i = 0; i < G_N_ELEMENTS (phones); i++) { + if (e_vcard_attribute_has_type (attr, phones [i].type_1) && + (phones [i].type_2 == NULL || e_vcard_attribute_has_type (attr, phones [i].type_2))) + return i; + } + + return -1; +} + static void fill_in_email (EContactEditor *editor) { @@ -466,6 +487,199 @@ extract_email (EContactEditor *editor) e_contact_set_attributes (editor->contact, E_CONTACT_EMAIL, attr_list); } +/* EContact can get attributes by field ID only, and there is none for TEL, so we need this */ +static GList * +get_attributes_named (EVCard *vcard, const gchar *attr_name) +{ + GList *attr_list_in; + GList *attr_list_out = NULL; + GList *l; + + attr_list_in = e_vcard_get_attributes (vcard); + + for (l = attr_list_in; l; l = g_list_next (l)) { + EVCardAttribute *attr = l->data; + const gchar *name; + + name = e_vcard_attribute_get_name (attr); + + if (!strcasecmp (attr_name, name)) { + attr_list_out = g_list_append (attr_list_out, e_vcard_attribute_copy (attr)); + } + } + + return attr_list_out; +} + +/* EContact can set attributes by field ID only, and there is none for TEL, so we need this */ +static void +set_attributes_named (EVCard *vcard, const gchar *attr_name, GList *attr_list) +{ + GList *l; + + e_vcard_remove_attributes (vcard, NULL, attr_name); + + for (l = attr_list; l; l = g_list_next (l)) { + EVCardAttribute *attr = l->data; + + e_vcard_add_attribute (vcard, e_vcard_attribute_copy (attr)); + } +} + +static void +fill_in_phone_record (EContactEditor *editor, gint record, const gchar *phone, gint phone_type) +{ + GtkWidget *phone_type_option_menu; + GtkWidget *phone_entry; + gchar *widget_name; + + widget_name = g_strdup_printf ("optionmenu-phone-%d", record); + phone_type_option_menu = glade_xml_get_widget (editor->gui, widget_name); + g_free (widget_name); + + widget_name = g_strdup_printf ("entry-phone-%d", record); + phone_entry = glade_xml_get_widget (editor->gui, widget_name); + g_free (widget_name); + + gtk_option_menu_set_history (GTK_OPTION_MENU (phone_type_option_menu), + phone_type >= 0 ? phone_type : 0); + set_entry_text (editor, GTK_ENTRY (phone_entry), phone ? phone : ""); +} + +static void +extract_phone_record (EContactEditor *editor, gint record, gchar **phone, gint *phone_type) +{ + GtkWidget *phone_type_option_menu; + GtkWidget *phone_entry; + gchar *widget_name; + + widget_name = g_strdup_printf ("optionmenu-phone-%d", record); + phone_type_option_menu = glade_xml_get_widget (editor->gui, widget_name); + g_free (widget_name); + + widget_name = g_strdup_printf ("entry-phone-%d", record); + phone_entry = glade_xml_get_widget (editor->gui, widget_name); + g_free (widget_name); + + *phone = g_strdup (gtk_entry_get_text (GTK_ENTRY (phone_entry))); + *phone_type = gtk_option_menu_get_history (GTK_OPTION_MENU (phone_type_option_menu)); +} + +static void +fill_in_phone (EContactEditor *editor) +{ + GList *phone_attr_list; + GList *l; + gint record_n = 1; + + phone_attr_list = get_attributes_named (E_VCARD (editor->contact), "TEL"); + + /* Fill in */ + + for (l = phone_attr_list; l && record_n <= 4; l = g_list_next (l)) { + EVCardAttribute *attr = l->data; + gchar *phone; + + phone = e_vcard_attribute_get_value (attr); + + fill_in_phone_record (editor, record_n, phone, + get_phone_type (attr)); + + record_n++; + } + + /* Clear remaining */ + + for ( ; record_n <= 4; record_n++) { + fill_in_phone_record (editor, record_n, NULL, -1); + } +} + +static void +extract_phone (EContactEditor *editor) +{ + GList *attr_list = NULL; + gint i; + + for (i = 1; i <= 4; i++) { + gchar *phone; + gint phone_type; + + extract_phone_record (editor, i, &phone, &phone_type); + + if (nonempty (phone)) { + EVCardAttribute *attr; + + attr = e_vcard_attribute_new ("", "TEL"); + + if (phone_type >= 0) { + const gchar *type_1; + const gchar *type_2; + + phone_index_to_type (phone_type, &type_1, &type_2); + + e_vcard_attribute_add_param_with_value ( + attr, e_vcard_attribute_param_new (EVC_TYPE), type_1); + + if (type_2) + e_vcard_attribute_add_param_with_value ( + attr, e_vcard_attribute_param_new (EVC_TYPE), type_2); + + } + + e_vcard_attribute_add_value (attr, phone); + + attr_list = g_list_append (attr_list, attr); + } + + g_free (phone); + } + + set_attributes_named (E_VCARD (editor->contact), "TEL", attr_list); +} + +static void +init_phone_record_type (EContactEditor *editor, gint record) +{ + GtkWidget *phone_type_option_menu; + GtkWidget *phone_type_menu; + GtkWidget *phone_entry; + gchar *widget_name; + gint i; + + widget_name = g_strdup_printf ("entry-phone-%d", record); + phone_entry = glade_xml_get_widget (editor->gui, widget_name); + g_free (widget_name); + + widget_name = g_strdup_printf ("optionmenu-phone-%d", record); + phone_type_option_menu = glade_xml_get_widget (editor->gui, widget_name); + g_free (widget_name); + + g_signal_connect (phone_type_option_menu, "changed", G_CALLBACK (widget_changed), editor); + g_signal_connect (phone_entry, "changed", G_CALLBACK (widget_changed), editor); + + phone_type_menu = gtk_menu_new (); + + for (i = 0; i < G_N_ELEMENTS (phones); i++) { + GtkWidget *item; + + item = gtk_menu_item_new_with_label (e_contact_pretty_name (phones [i].field_id)); + gtk_menu_shell_append (GTK_MENU_SHELL (phone_type_menu), item); + } + + gtk_widget_show_all (phone_type_menu); + gtk_option_menu_set_menu (GTK_OPTION_MENU (phone_type_option_menu), phone_type_menu); +} + +static void +init_phone (EContactEditor *editor) +{ + init_phone_record_type (editor, 1); + init_phone_record_type (editor, 2); + init_phone_record_type (editor, 3); + init_phone_record_type (editor, 4); +} + static void init_im_record_location (EContactEditor *editor, gint record) { @@ -785,26 +999,6 @@ extract_address (EContactEditor *editor) } static void -connect_arrow_button_signal (EContactEditor *editor, gchar *button_xml, GCallback func) -{ - GladeXML *gui = editor->gui; - GtkWidget *button = glade_xml_get_widget(gui, button_xml); - - if (button && GTK_IS_BUTTON(button)) { - g_signal_connect(button, "button_press_event", func, editor); - } -} - -static void -connect_arrow_button_signals (EContactEditor *editor) -{ - connect_arrow_button_signal(editor, "button-phone-1", G_CALLBACK (_phone_arrow_pressed)); - connect_arrow_button_signal(editor, "button-phone-2", G_CALLBACK (_phone_arrow_pressed)); - connect_arrow_button_signal(editor, "button-phone-3", G_CALLBACK (_phone_arrow_pressed)); - connect_arrow_button_signal(editor, "button-phone-4", G_CALLBACK (_phone_arrow_pressed)); -} - -static void wants_html_changed (GtkWidget *widget, EContactEditor *editor) { gboolean wants_html; @@ -818,28 +1012,6 @@ wants_html_changed (GtkWidget *widget, EContactEditor *editor) } static void -phone_entry_changed (GtkWidget *widget, EContactEditor *editor) -{ - int which; - GtkEntry *entry = GTK_ENTRY(widget); - - if ( widget == glade_xml_get_widget(editor->gui, "entry-phone-1") ) - which = 1; - else if ( widget == glade_xml_get_widget(editor->gui, "entry-phone-2") ) - which = 2; - else if ( widget == glade_xml_get_widget(editor->gui, "entry-phone-3") ) - which = 3; - else if ( widget == glade_xml_get_widget(editor->gui, "entry-phone-4") ) - which = 4; - else - return; - - e_contact_set(editor->contact, phones [editor->phone_choice [which - 1]], (char*)gtk_entry_get_text(entry)); - - widget_changed (widget, editor); -} - -static void new_target_cb (EBook *new_book, EBookStatus status, EContactEditor *editor) { editor->load_source_id = 0; @@ -1116,15 +1288,6 @@ field_changed (GtkWidget *widget, EContactEditor *editor) } static void -set_entry_changed_signal_phone(EContactEditor *editor, char *id) -{ - GtkWidget *widget = glade_xml_get_widget(editor->gui, id); - if (widget && GTK_IS_ENTRY(widget)) - g_signal_connect(widget, "changed", - G_CALLBACK (phone_entry_changed), editor); -} - -static void widget_changed (GtkWidget *widget, EContactEditor *editor) { if (!editor->target_editable) { @@ -1162,10 +1325,6 @@ static void set_entry_changed_signals(EContactEditor *editor) { GtkWidget *widget; - set_entry_changed_signal_phone(editor, "entry-phone-1"); - set_entry_changed_signal_phone(editor, "entry-phone-2"); - set_entry_changed_signal_phone(editor, "entry-phone-3"); - set_entry_changed_signal_phone(editor, "entry-phone-4"); widget = glade_xml_get_widget(editor->gui, "entry-fullname"); if (widget && GTK_IS_ENTRY(widget)) { @@ -1594,10 +1753,10 @@ e_contact_editor_init (EContactEditor *e_contact_editor) e_contact_editor->app = glade_xml_get_widget (gui, "contact editor"); - connect_arrow_button_signals(e_contact_editor); set_entry_changed_signals(e_contact_editor); init_email (e_contact_editor); + init_phone (e_contact_editor); init_im (e_contact_editor); init_address (e_contact_editor); @@ -1970,118 +2129,6 @@ e_contact_editor_get_property (GObject *object, guint prop_id, GValue *value, GP } } -static gint -_arrow_pressed (GtkWidget *widget, GdkEventButton *button, EContactEditor *editor, GtkWidget *popup, GList **list, GnomeUIInfo **info, gchar *label) -{ - gint menu_item; - - g_signal_stop_emission_by_name (widget, "button_press_event"); - - gtk_widget_realize(popup); - menu_item = gnome_popup_menu_do_popup_modal(popup, NULL, NULL, button, editor, widget); - if ( menu_item != -1 ) { - GtkWidget *label_widget = glade_xml_get_widget(editor->gui, label); - if (label_widget && GTK_IS_LABEL(label_widget)) { - g_object_set (label_widget, - "label", _(g_list_nth_data(*list, menu_item)), - NULL); - } - } - return menu_item; -} - -static void -e_contact_editor_build_ui_info(GList *list, GnomeUIInfo **infop) -{ - GnomeUIInfo *info; - GnomeUIInfo singleton = { GNOME_APP_UI_TOGGLEITEM, NULL, NULL, NULL, NULL, NULL, GNOME_APP_PIXMAP_NONE, 0, 0, 0, NULL }; - GnomeUIInfo end = GNOMEUIINFO_END; - int length; - int i; - - info = *infop; - - if ( info ) - g_free(info); - length = g_list_length( list ); - info = g_new(GnomeUIInfo, length + 2); - for (i = 0; i < length; i++) { - info[i] = singleton; - info[i].label = _(list->data); - list = list->next; - } - info[i] = end; - - *infop = info; -} - -static void -e_contact_editor_build_phone_ui (EContactEditor *editor) -{ - if (editor->phone_list == NULL) { - int i; - - for (i = 0; i < G_N_ELEMENTS (phones); i ++) { - editor->phone_list = g_list_append(editor->phone_list, g_strdup(e_contact_pretty_name (phones[i]))); - } - } - if (editor->phone_info == NULL) { - e_contact_editor_build_ui_info(editor->phone_list, &editor->phone_info); - - if ( editor->phone_popup ) - g_object_unref(editor->phone_popup); - - editor->phone_popup = gnome_popup_menu_new(editor->phone_info); - g_object_ref (editor->phone_popup); - gtk_object_sink (GTK_OBJECT (editor->phone_popup)); - } -} - -static void -_phone_arrow_pressed (GtkWidget *widget, GdkEventButton *button, EContactEditor *editor) -{ - int which; - int i; - gchar *label; - gchar *entry; - int result; - if ( widget == glade_xml_get_widget(editor->gui, "button-phone-1") ) { - which = 1; - } else if ( widget == glade_xml_get_widget(editor->gui, "button-phone-2") ) { - which = 2; - } else if ( widget == glade_xml_get_widget(editor->gui, "button-phone-3") ) { - which = 3; - } else if ( widget == glade_xml_get_widget(editor->gui, "button-phone-4") ) { - which = 4; - } else - return; - - label = g_strdup_printf("label-phone-%d", which); - entry = g_strdup_printf("entry-phone-%d", which); - - e_contact_editor_build_phone_ui (editor); - - for(i = 0; i < G_N_ELEMENTS (phones); i++) { - char *phone = e_contact_get (editor->contact, phones[i]); - gtk_check_menu_item_set_active(GTK_CHECK_MENU_ITEM(editor->phone_info[i].widget), - phone && *phone); - g_free (phone); - } - - result = _arrow_pressed (widget, button, editor, editor->phone_popup, &editor->phone_list, &editor->phone_info, label); - - if (result != -1) { - GtkWidget *w = glade_xml_get_widget (editor->gui, entry); - editor->phone_choice[which - 1] = result; - set_fields (editor); - enable_widget (glade_xml_get_widget (editor->gui, label), TRUE); - enable_widget (w, editor->target_editable); - } - - g_free(label); - g_free(entry); -} - static void set_entry_text (EContactEditor *editor, GtkEntry *entry, const gchar *string) { @@ -2101,12 +2148,6 @@ set_entry_text (EContactEditor *editor, GtkEntry *entry, const gchar *string) } static void -set_phone_field(EContactEditor *editor, GtkWidget *entry, const char *phone_number) -{ - set_entry_text (editor, GTK_ENTRY(entry), phone_number ? phone_number : ""); -} - -static void set_source_field (EContactEditor *editor) { GtkWidget *source_menu; @@ -2124,25 +2165,8 @@ set_source_field (EContactEditor *editor) static void set_fields(EContactEditor *editor) { - GtkWidget *entry; - - entry = glade_xml_get_widget(editor->gui, "entry-phone-1"); - if (entry && GTK_IS_ENTRY(entry)) - set_phone_field(editor, entry, e_contact_get_const(editor->contact, phones[editor->phone_choice[0]])); - - entry = glade_xml_get_widget(editor->gui, "entry-phone-2"); - if (entry && GTK_IS_ENTRY(entry)) - set_phone_field(editor, entry, e_contact_get_const(editor->contact, phones[editor->phone_choice[1]])); - - entry = glade_xml_get_widget(editor->gui, "entry-phone-3"); - if (entry && GTK_IS_ENTRY(entry)) - set_phone_field(editor, entry, e_contact_get_const(editor->contact, phones[editor->phone_choice[2]])); - - entry = glade_xml_get_widget(editor->gui, "entry-phone-4"); - if (entry && GTK_IS_ENTRY(entry)) - set_phone_field(editor, entry, e_contact_get_const(editor->contact, phones[editor->phone_choice[3]])); - fill_in_email (editor); + fill_in_phone (editor); fill_in_im (editor); fill_in_address (editor); set_source_field (editor); @@ -2264,7 +2288,6 @@ enable_writable_fields(EContactEditor *editor) EIterator *iter; GHashTable *dropdown_hash, *supported_hash; int i; - char *widget_name; if (!fields) return; @@ -2272,28 +2295,9 @@ enable_writable_fields(EContactEditor *editor) dropdown_hash = g_hash_table_new (g_str_hash, g_str_equal); supported_hash = g_hash_table_new (g_str_hash, g_str_equal); - /* build our hashtable of the drop down menu items */ - e_contact_editor_build_phone_ui (editor); - for (i = 0; i < G_N_ELEMENTS (phones); i ++) - g_hash_table_insert (dropdown_hash, - (char*)e_contact_field_name(phones[i]), - editor->phone_info[i].widget); - /* then disable them all */ g_hash_table_foreach (dropdown_hash, (GHFunc)disable_widget_foreach, NULL); - /* disable the label widgets for the dropdowns (4 phone, 1 - email and the toggle button, and 1 address and one for - the full address button */ - for (i = 0; i < 4; i ++) { - widget_name = g_strdup_printf ("label-phone-%d", i+1); - enable_widget (glade_xml_get_widget (editor->gui, widget_name), FALSE); - g_free (widget_name); - widget_name = g_strdup_printf ("entry-phone-%d", i+1); - enable_widget (glade_xml_get_widget (editor->gui, widget_name), FALSE); - g_free (widget_name); - } - enable_widget (glade_xml_get_widget (editor->gui, "checkbutton-htmlmail"), FALSE); editor->fullname_editable = FALSE; @@ -2328,16 +2332,6 @@ enable_writable_fields(EContactEditor *editor) if (!strcmp (field, e_contact_field_name (emails[editor->email_choice]))) { enable_widget (glade_xml_get_widget (editor->gui, "checkbutton-htmlmail"), editor->target_editable); } - else for (i = 0; i < 4; i ++) { - if (!strcmp (field, e_contact_field_name (phones[editor->phone_choice[i]]))) { - widget_name = g_strdup_printf ("label-phone-%d", i+1); - enable_widget (glade_xml_get_widget (editor->gui, widget_name), TRUE); - g_free (widget_name); - widget_name = g_strdup_printf ("entry-phone-%d", i+1); - enable_widget (glade_xml_get_widget (editor->gui, widget_name), editor->target_editable); - g_free (widget_name); - } - } } /* handle the label next to the dropdown widgets */ @@ -2593,6 +2587,7 @@ extract_info(EContactEditor *editor) } extract_email (editor); + extract_phone (editor); extract_im (editor); extract_address (editor); } |