From 73eafe0999fe4f83e6428886bf63c09a03ccdcf6 Mon Sep 17 00:00:00 2001 From: Christopher James Lahey Date: Fri, 5 May 2000 12:55:01 +0000 Subject: Added e-card-simple.c and e-card-simple.h. 2000-05-05 Christopher James Lahey * backend/ebook/Makefile.am: Added e-card-simple.c and e-card-simple.h. * backend/ebook/e-card-simple.c, backend/ebook/e-card-simple.h: New card wrapper class to simplify things. * contact-editor/e-contact-editor.c, contact-editor/e-contact-editor.h: Changed e-contact-editor to use ECardSimple a bit. svn path=/trunk/; revision=2815 --- addressbook/backend/ebook/Makefile.am | 2 + addressbook/backend/ebook/e-card-simple.c | 713 ++++++++++++++++++++++++++++++ addressbook/backend/ebook/e-card-simple.h | 115 +++++ 3 files changed, 830 insertions(+) create mode 100644 addressbook/backend/ebook/e-card-simple.c create mode 100644 addressbook/backend/ebook/e-card-simple.h (limited to 'addressbook/backend') diff --git a/addressbook/backend/ebook/Makefile.am b/addressbook/backend/ebook/Makefile.am index 970618c53a..9b4634f49e 100644 --- a/addressbook/backend/ebook/Makefile.am +++ b/addressbook/backend/ebook/Makefile.am @@ -36,6 +36,7 @@ libebook_la_SOURCES = \ e-card-iterator.c \ e-card-list-iterator.c \ e-card-list.c \ + e-card-simple.c \ e-card.c libebookincludedir = $(includedir)/evolution/ebook @@ -49,6 +50,7 @@ libebookinclude_HEADERS = \ e-card-iterator.h \ e-card-list-iterator.h \ e-card-list.h \ + e-card-simple.h \ e-card.h test_client_SOURCES = \ diff --git a/addressbook/backend/ebook/e-card-simple.c b/addressbook/backend/ebook/e-card-simple.c new file mode 100644 index 0000000000..495fc71e80 --- /dev/null +++ b/addressbook/backend/ebook/e-card-simple.c @@ -0,0 +1,713 @@ +/* -*- Mode: C; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 8 -*- */ +/* + * Authors: + * Chris Lahey + * Arturo Espinosa (arturo@nuclecu.unam.mx) + * Nat Friedman (nat@helixcode.com) + * + * Copyright (C) 2000 Helix Code, Inc. + * Copyright (C) 1999 The Free Software Foundation + */ + +#include +#include +#include +#include +#include + +#include +#include "e-card-simple.h" + +/* Object argument IDs */ +enum { + ARG_0, + ARG_CARD, +#if 0 + ARG_FILE_AS, + ARG_FULL_NAME, + ARG_NAME, + ARG_ADDRESS, + ARG_ADDRESS_LABEL, + ARG_PHONE, + ARG_EMAIL, + ARG_BIRTH_DATE, + ARG_URL, + ARG_ORG, + ARG_ORG_UNIT, + ARG_OFFICE, + ARG_TITLE, + ARG_ROLE, + ARG_MANAGER, + ARG_ASSISTANT, + ARG_NICKNAME, + ARG_SPOUSE, + ARG_ANNIVERSARY, + ARG_FBURL, + ARG_NOTE, + ARG_ID +#endif +}; + +static void e_card_simple_init (ECardSimple *simple); +static void e_card_simple_class_init (ECardSimpleClass *klass); + +static void e_card_simple_destroy (GtkObject *object); +static void e_card_simple_set_arg (GtkObject *object, GtkArg *arg, guint arg_id); +static void e_card_simple_get_arg (GtkObject *object, GtkArg *arg, guint arg_id); + +static void fill_in_info(ECardSimple *simple); + +ECardPhoneFlags phone_correspondences[] = { + 0xFF, /* E_CARD_SIMPLE_PHONE_ID_ASSISTANT, */ + E_CARD_PHONE_WORK | E_CARD_PHONE_VOICE, /* E_CARD_SIMPLE_PHONE_ID_BUSINESS, */ + E_CARD_PHONE_WORK | E_CARD_PHONE_VOICE, /* E_CARD_SIMPLE_PHONE_ID_BUSINESS_2, */ + E_CARD_PHONE_WORK | E_CARD_PHONE_FAX, /* E_CARD_SIMPLE_PHONE_ID_BUSINESS_FAX, */ + 0xFF, /* E_CARD_SIMPLE_PHONE_ID_CALLBACK, */ + E_CARD_PHONE_CAR | E_CARD_PHONE_VOICE, /* E_CARD_SIMPLE_PHONE_ID_CAR, */ + 0xFF, /* E_CARD_SIMPLE_PHONE_ID_COMPANY, */ + E_CARD_PHONE_HOME | E_CARD_PHONE_VOICE, /* E_CARD_SIMPLE_PHONE_ID_HOME, */ + E_CARD_PHONE_HOME | E_CARD_PHONE_VOICE, /* E_CARD_SIMPLE_PHONE_ID_HOME_2, */ + E_CARD_PHONE_HOME | E_CARD_PHONE_FAX, /* E_CARD_SIMPLE_PHONE_ID_HOME_FAX, */ + E_CARD_PHONE_ISDN, /* E_CARD_SIMPLE_PHONE_ID_ISDN, */ + E_CARD_PHONE_CELL | E_CARD_PHONE_VOICE, /* E_CARD_SIMPLE_PHONE_ID_MOBILE, */ + E_CARD_PHONE_VOICE, /* E_CARD_SIMPLE_PHONE_ID_OTHER, */ + 0xFF, /* E_CARD_SIMPLE_PHONE_ID_OTHER_FAX, */ + E_CARD_PHONE_PAGER | E_CARD_PHONE_VOICE, /* E_CARD_SIMPLE_PHONE_ID_PAGER, */ + E_CARD_PHONE_PREF, /* E_CARD_SIMPLE_PHONE_ID_PRIMARY, */ + 0xFF, /* E_CARD_SIMPLE_PHONE_ID_RADIO, */ + 0xFF, /* E_CARD_SIMPLE_PHONE_ID_TELEX, */ + 0xFF, /* E_CARD_SIMPLE_PHONE_ID_TTYTTD, */ +}; + +ECardAddressFlags addr_correspondences[] = { + E_CARD_ADDR_WORK, /* E_CARD_SIMPLE_ADDRESS_ID_BUSINESS, */ + E_CARD_ADDR_HOME, /* E_CARD_SIMPLE_ADDRESS_ID_HOME, */ + E_CARD_ADDR_POSTAL, /* E_CARD_SIMPLE_ADDRESS_ID_OTHER, */ +}; + +/** + * e_card_simple_get_type: + * @void: + * + * Registers the &ECardSimple class if necessary, and returns the type ID + * associated to it. + * + * Return value: The type ID of the &ECardSimple class. + **/ +GtkType +e_card_simple_get_type (void) +{ + static GtkType simple_type = 0; + + if (!simple_type) { + GtkTypeInfo simple_info = { + "ECardSimple", + sizeof (ECardSimple), + sizeof (ECardSimpleClass), + (GtkClassInitFunc) e_card_simple_class_init, + (GtkObjectInitFunc) e_card_simple_init, + NULL, /* reserved_1 */ + NULL, /* reserved_2 */ + (GtkClassInitFunc) NULL + }; + + simple_type = gtk_type_unique (gtk_object_get_type (), &simple_info); + } + + return simple_type; +} + +/** + * e_card_simple_new: + * @VCard: a string in vCard format + * + * Returns: a new #ECardSimple that wraps the @VCard. + */ +ECardSimple * +e_card_simple_new (ECard *card) +{ + ECardSimple *simple = E_CARD_SIMPLE(gtk_type_new(e_card_simple_get_type())); + gtk_object_set(GTK_OBJECT(simple), + "card", card, + NULL); + return simple; +} + +ECardSimple *e_card_simple_duplicate(ECardSimple *simple) +{ + char *vcard = e_card_simple_get_vcard(simple); + ECard *card = e_card_new(vcard); + ECardSimple *new_simple = e_card_simple_new(card); + g_free (vcard); + return new_simple; +} + +/** + * e_card_simple_get_id: + * @simple: an #ECardSimple + * + * Returns: a string representing the id of the simple, which is unique + * within its book. + */ +char * +e_card_simple_get_id (ECardSimple *simple) +{ + if (simple->card) + return e_card_get_id(simple->card); + else + return ""; +} + +/** + * e_card_simple_get_id: + * @simple: an #ECardSimple + * @id: a id in string format + * + * Sets the identifier of a simple, which should be unique within its + * book. + */ +void +e_card_simple_set_id (ECardSimple *simple, const char *id) +{ + if ( simple->card ) + e_card_set_id(simple->card, id); +} + +/** + * e_card_simple_get_vcard: + * @simple: an #ECardSimple + * + * Returns: a string in vcard format, which is wrapped by the @simple. + */ +char +*e_card_simple_get_vcard (ECardSimple *simple) +{ + if (simple->card) + return e_card_get_vcard(simple->card); + else + return g_strdup(""); +} + +static void +e_card_simple_class_init (ECardSimpleClass *klass) +{ + GtkObjectClass *object_class; + + object_class = GTK_OBJECT_CLASS(klass); + + gtk_object_add_arg_type ("ECardSimple::card", + GTK_TYPE_OBJECT, GTK_ARG_READWRITE, ARG_CARD); +#if 0 + gtk_object_add_arg_type ("ECardSimple::file_as", + GTK_TYPE_STRING, GTK_ARG_READWRITE, ARG_FILE_AS); + gtk_object_add_arg_type ("ECardSimple::full_name", + GTK_TYPE_STRING, GTK_ARG_READWRITE, ARG_FULL_NAME); + gtk_object_add_arg_type ("ECardSimple::name", + GTK_TYPE_POINTER, GTK_ARG_READWRITE, ARG_NAME); + gtk_object_add_arg_type ("ECardSimple::address", + GTK_TYPE_OBJECT, GTK_ARG_READABLE, ARG_ADDRESS); + gtk_object_add_arg_type ("ECardSimple::address_label", + GTK_TYPE_OBJECT, GTK_ARG_READABLE, ARG_ADDRESS_LABEL); + gtk_object_add_arg_type ("ECardSimple::phone", + GTK_TYPE_OBJECT, GTK_ARG_READABLE, ARG_PHONE); + gtk_object_add_arg_type ("ECardSimple::email", + GTK_TYPE_OBJECT, GTK_ARG_READABLE, ARG_EMAIL); + gtk_object_add_arg_type ("ECardSimple::birth_date", + GTK_TYPE_POINTER, GTK_ARG_READWRITE, ARG_BIRTH_DATE); + gtk_object_add_arg_type ("ECardSimple::url", + GTK_TYPE_STRING, GTK_ARG_READWRITE, ARG_URL); + gtk_object_add_arg_type ("ECardSimple::org", + GTK_TYPE_STRING, GTK_ARG_READWRITE, ARG_ORG); + gtk_object_add_arg_type ("ECardSimple::org_unit", + GTK_TYPE_STRING, GTK_ARG_READWRITE, ARG_ORG_UNIT); + gtk_object_add_arg_type ("ECardSimple::office", + GTK_TYPE_STRING, GTK_ARG_READWRITE, ARG_OFFICE); + gtk_object_add_arg_type ("ECardSimple::title", + GTK_TYPE_STRING, GTK_ARG_READWRITE, ARG_TITLE); + gtk_object_add_arg_type ("ECardSimple::role", + GTK_TYPE_STRING, GTK_ARG_READWRITE, ARG_ROLE); + gtk_object_add_arg_type ("ECardSimple::manager", + GTK_TYPE_STRING, GTK_ARG_READWRITE, ARG_MANAGER); + gtk_object_add_arg_type ("ECardSimple::assistant", + GTK_TYPE_STRING, GTK_ARG_READWRITE, ARG_ASSISTANT); + gtk_object_add_arg_type ("ECardSimple::nickname", + GTK_TYPE_STRING, GTK_ARG_READWRITE, ARG_NICKNAME); + gtk_object_add_arg_type ("ECardSimple::spouse", + GTK_TYPE_STRING, GTK_ARG_READWRITE, ARG_SPOUSE); + gtk_object_add_arg_type ("ECardSimple::anniversary", + GTK_TYPE_POINTER, GTK_ARG_READWRITE, ARG_ANNIVERSARY); + gtk_object_add_arg_type ("ECardSimple::fburl", + GTK_TYPE_STRING, GTK_ARG_READWRITE, ARG_FBURL); + gtk_object_add_arg_type ("ECardSimple::note", + GTK_TYPE_STRING, GTK_ARG_READWRITE, ARG_NOTE); + gtk_object_add_arg_type ("ECardSimple::id", + GTK_TYPE_STRING, GTK_ARG_READWRITE, ARG_ID); +#endif + + object_class->destroy = e_card_simple_destroy; + object_class->get_arg = e_card_simple_get_arg; + object_class->set_arg = e_card_simple_set_arg; +} + +/* + * ECardSimple lifecycle management and vcard loading/saving. + */ + +static void +e_card_simple_destroy (GtkObject *object) +{ +} + + +/* Set_arg handler for the simple */ +static void +e_card_simple_set_arg (GtkObject *object, GtkArg *arg, guint arg_id) +{ + ECardSimple *simple; + + simple = E_CARD_SIMPLE (object); + + switch (arg_id) { + case ARG_CARD: + if (simple->card) + gtk_object_unref(GTK_OBJECT(simple->card)); + if (GTK_VALUE_OBJECT(*arg)) + simple->card = E_CARD(GTK_VALUE_OBJECT(*arg)); + else + simple->card = NULL; + if(simple->card) + gtk_object_ref(GTK_OBJECT(simple->card)); + fill_in_info(simple); + break; +#if 0 + case ARG_FILE_AS: + if (simple->file_as) + g_free(simple->file_as); + simple->file_as = g_strdup(GTK_VALUE_STRING(*arg)); + break; + case ARG_FULL_NAME: + if ( simple->fname ) + g_free(simple->fname); + simple->fname = g_strdup(GTK_VALUE_STRING(*arg)); + break; + case ARG_NAME: + if ( simple->name ) + e_card_simple_name_free(simple->name); + simple->name = GTK_VALUE_POINTER(*arg); + break; + case ARG_BIRTH_DATE: + if ( simple->bday ) + g_free(simple->bday); + simple->bday = GTK_VALUE_POINTER(*arg); + break; + case ARG_URL: + if ( simple->url ) + g_free(simple->url); + simple->url = g_strdup(GTK_VALUE_STRING(*arg)); + break; + case ARG_ORG: + if (simple->org) + g_free(simple->org); + simple->org = g_strdup(GTK_VALUE_STRING(*arg)); + break; + case ARG_ORG_UNIT: + if (simple->org_unit) + g_free(simple->org_unit); + simple->org_unit = g_strdup(GTK_VALUE_STRING(*arg)); + break; + case ARG_OFFICE: + if (simple->office) + g_free(simple->office); + simple->office = g_strdup(GTK_VALUE_STRING(*arg)); + break; + case ARG_TITLE: + if ( simple->title ) + g_free(simple->title); + simple->title = g_strdup(GTK_VALUE_STRING(*arg)); + break; + case ARG_ROLE: + if (simple->role) + g_free(simple->role); + simple->role = g_strdup(GTK_VALUE_STRING(*arg)); + break; + case ARG_MANAGER: + if (simple->manager) + g_free(simple->manager); + simple->manager = g_strdup(GTK_VALUE_STRING(*arg)); + break; + case ARG_ASSISTANT: + if (simple->assistant) + g_free(simple->assistant); + simple->assistant = g_strdup(GTK_VALUE_STRING(*arg)); + break; + case ARG_NICKNAME: + if (simple->nickname) + g_free(simple->nickname); + simple->nickname = g_strdup(GTK_VALUE_STRING(*arg)); + break; + case ARG_SPOUSE: + if (simple->spouse) + g_free(simple->spouse); + simple->spouse = g_strdup(GTK_VALUE_STRING(*arg)); + break; + case ARG_ANNIVERSARY: + if ( simple->anniversary ) + g_free(simple->anniversary); + simple->anniversary = GTK_VALUE_POINTER(*arg); + break; + case ARG_FBURL: + if (simple->fburl) + g_free(simple->fburl); + simple->fburl = g_strdup(GTK_VALUE_STRING(*arg)); + break; + case ARG_NOTE: + if (simple->note) + g_free (simple->note); + simple->note = g_strdup(GTK_VALUE_STRING(*arg)); + break; + case ARG_ID: + if (simple->id) + g_free(simple->id); + simple->id = g_strdup(GTK_VALUE_STRING(*arg)); + break; +#endif + default: + return; + } +} + +/* Get_arg handler for the simple */ +static void +e_card_simple_get_arg (GtkObject *object, GtkArg *arg, guint arg_id) +{ + ECardSimple *simple; + + simple = E_CARD_SIMPLE (object); + + switch (arg_id) { + case ARG_CARD: + e_card_simple_sync_card(simple); + if (simple->card) + GTK_VALUE_OBJECT (*arg) = GTK_OBJECT(simple->card); + else + GTK_VALUE_OBJECT (*arg) = NULL; + break; +#if 0 + case ARG_FILE_AS: + GTK_VALUE_STRING (*arg); + break; + case ARG_FULL_NAME: + GTK_VALUE_STRING (*arg) = simple->fname; + break; + case ARG_NAME: + GTK_VALUE_POINTER(*arg) = simple->name; + break; + case ARG_ADDRESS: + if (!simple->address) + simple->address = e_card_simple_list_new((ECardSimpleListCopyFunc) e_card_simple_delivery_address_copy, + (ECardSimpleListFreeFunc) e_card_simple_delivery_address_free, + NULL); + GTK_VALUE_OBJECT(*arg) = GTK_OBJECT(simple->address); + break; + case ARG_ADDRESS_LABEL: + if (!simple->address_label) + simple->address_label = e_card_simple_list_new((ECardSimpleListCopyFunc) e_card_simple_address_label_copy, + (ECardSimpleListFreeFunc) e_card_simple_address_label_free, + NULL); + GTK_VALUE_OBJECT(*arg) = GTK_OBJECT(simple->address_label); + break; + case ARG_PHONE: + if (!simple->phone) + simple->phone = e_card_simple_list_new((ECardSimpleListCopyFunc) e_card_simple_phone_copy, + (ECardSimpleListFreeFunc) e_card_simple_phone_free, + NULL); + GTK_VALUE_OBJECT(*arg) = GTK_OBJECT(simple->phone); + break; + case ARG_EMAIL: + if (!simple->email) + simple->email = e_card_simple_list_new((ECardSimpleListCopyFunc) g_strdup, + (ECardSimpleListFreeFunc) g_free, + NULL); + GTK_VALUE_OBJECT(*arg) = GTK_OBJECT(simple->email); + break; + case ARG_BIRTH_DATE: + GTK_VALUE_POINTER(*arg) = simple->bday; + break; + case ARG_URL: + GTK_VALUE_STRING(*arg) = simple->url; + break; + case ARG_ORG: + GTK_VALUE_STRING(*arg) = simple->org; + break; + case ARG_ORG_UNIT: + GTK_VALUE_STRING(*arg) = simple->org_unit; + break; + case ARG_OFFICE: + GTK_VALUE_STRING(*arg) = simple->office; + break; + case ARG_TITLE: + GTK_VALUE_STRING(*arg) = simple->title; + break; + case ARG_ROLE: + GTK_VALUE_STRING(*arg) = simple->role; + break; + case ARG_MANAGER: + GTK_VALUE_STRING(*arg) = simple->manager; + break; + case ARG_ASSISTANT: + GTK_VALUE_STRING(*arg) = simple->assistant; + break; + case ARG_NICKNAME: + GTK_VALUE_STRING(*arg) = simple->nickname; + break; + case ARG_SPOUSE: + GTK_VALUE_STRING(*arg) = simple->spouse; + break; + case ARG_ANNIVERSARY: + GTK_VALUE_POINTER(*arg) = simple->anniversary; + break; + case ARG_FBURL: + GTK_VALUE_STRING(*arg) = simple->fburl; + break; + case ARG_NOTE: + GTK_VALUE_STRING(*arg) = simple->note; + break; + case ARG_ID: + GTK_VALUE_STRING(*arg) = simple->id; + break; +#endif + default: + arg->type = GTK_TYPE_INVALID; + break; + } +} + + +/** + * e_card_simple_init: + */ +static void +e_card_simple_init (ECardSimple *simple) +{ + int i; + simple->card = NULL; + for(i = 0; i < E_CARD_SIMPLE_PHONE_ID_LAST; i++) + simple->phone[i] = NULL; + for(i = 0; i < E_CARD_SIMPLE_EMAIL_ID_LAST; i++) + simple->email[i] = NULL; + for(i = 0; i < E_CARD_SIMPLE_ADDRESS_ID_LAST; i++) + simple->address[i] = NULL; +} + +static void +fill_in_info(ECardSimple *simple) +{ + ECard *card = simple->card; + if (card) { + ECardList *address_list; + ECardList *phone_list; + ECardList *email_list; + const ECardPhone *phone; + const char *email; + const ECardAddrLabel *address; + + ECardIterator *iterator; + + gtk_object_get(GTK_OBJECT(card), + "address_label", &address_list, + "phone", &phone_list, + "email", &email_list, + NULL); + for (iterator = e_card_list_get_iterator(phone_list); e_card_iterator_is_valid(iterator); e_card_iterator_next(iterator)) { + int i; + phone = e_card_iterator_get(iterator); + for (i = 0; i < E_CARD_SIMPLE_PHONE_ID_LAST; i ++) { + if (((phone->flags & phone_correspondences[i]) == phone_correspondences[i]) && (simple->phone[i] == NULL)) { + simple->phone[i] = e_card_phone_copy(phone); + break; + } + } + } + gtk_object_unref(GTK_OBJECT(iterator)); + + for (iterator = e_card_list_get_iterator(email_list); e_card_iterator_is_valid(iterator); e_card_iterator_next(iterator)) { + int i; + email = e_card_iterator_get(iterator); + for (i = 0; i < E_CARD_SIMPLE_EMAIL_ID_LAST; i ++) { + if ((simple->email[i] == NULL)) { + simple->email[i] = g_strdup(email); + break; + } + } + } + gtk_object_unref(GTK_OBJECT(iterator)); + + for (iterator = e_card_list_get_iterator(address_list); e_card_iterator_is_valid(iterator); e_card_iterator_next(iterator)) { + int i; + address = e_card_iterator_get(iterator); + for (i = 0; i < E_CARD_SIMPLE_ADDRESS_ID_LAST; i ++) { + if (((address->flags & addr_correspondences[i]) == addr_correspondences[i]) && (simple->address[i] == NULL)) { + simple->address[i] = e_card_address_label_copy(address); + break; + } + } + } + gtk_object_unref(GTK_OBJECT(iterator)); + } +} + +void +e_card_simple_sync_card(ECardSimple *simple) +{ + ECard *card = simple->card; + if (card) { + ECardList *address_list; + ECardList *phone_list; + ECardList *email_list; + const ECardPhone *phone; + const ECardAddrLabel *address; + const char *email; + int i; + int iterator_next = 1; + + ECardIterator *iterator; + + gtk_object_get(GTK_OBJECT(card), + "address_label", &address_list, + "phone", &phone_list, + "email", &email_list, + NULL); + + for (iterator = e_card_list_get_iterator(phone_list); e_card_iterator_is_valid(iterator); iterator_next ? e_card_iterator_next(iterator) : FALSE ) { + int i; + phone = e_card_iterator_get(iterator); + iterator_next = 1; + for (i = 0; i < E_CARD_SIMPLE_PHONE_ID_LAST; i ++) { + if ((phone->flags & phone_correspondences[i]) == phone_correspondences[i]) { + if (simple->phone[i]) { + if (simple->phone[i]->number && *simple->phone[i]->number) { + e_card_iterator_set(iterator, simple->phone[i]); + } else { + e_card_iterator_delete(iterator); + iterator_next = 0; + } + e_card_phone_free(simple->phone[i]); + simple->phone[i] = NULL; + break; + } + } + } + } + gtk_object_unref(GTK_OBJECT(iterator)); + for (i = 0; i < E_CARD_SIMPLE_PHONE_ID_LAST; i ++) { + if (simple->phone[i]) { + simple->phone[i]->flags = phone_correspondences[i]; + e_card_list_append(phone_list, simple->phone[i]); + e_card_phone_free(simple->phone[i]); + simple->phone[i] = NULL; + } + } + + for (iterator = e_card_list_get_iterator(email_list); e_card_iterator_is_valid(iterator); iterator_next ? e_card_iterator_next(iterator) : FALSE ) { + int i; + email = e_card_iterator_get(iterator); + iterator_next = 1; + for (i = 0; i < E_CARD_SIMPLE_EMAIL_ID_LAST; i ++) { + if (simple->email[i]) { + if (*simple->email[i]) { + e_card_iterator_set(iterator, simple->email[i]); + } else { + e_card_iterator_delete(iterator); + iterator_next = 0; + } + g_free(simple->email[i]); + simple->email[i] = NULL; + break; + } + } + } + gtk_object_unref(GTK_OBJECT(iterator)); + for (i = 0; i < E_CARD_SIMPLE_EMAIL_ID_LAST; i ++) { + if (simple->email[i]) { + e_card_list_append(email_list, simple->email[i]); + g_free(simple->email[i]); + simple->email[i] = NULL; + } + } + + for (iterator = e_card_list_get_iterator(address_list); e_card_iterator_is_valid(iterator); iterator_next ? e_card_iterator_next(iterator) : FALSE ) { + int i; + address = e_card_iterator_get(iterator); + iterator_next = 1; + for (i = 0; i < E_CARD_SIMPLE_ADDRESS_ID_LAST; i ++) { + if ((address->flags & addr_correspondences[i]) == addr_correspondences[i]) { + if (simple->address[i]) { + if (simple->address[i]->data && *simple->address[i]->data) { + e_card_iterator_set(iterator, simple->address[i]); + } else { + e_card_iterator_delete(iterator); + iterator_next = 0; + } + e_card_address_label_free(simple->address[i]); + simple->address[i] = NULL; + break; + } + } + } + } + gtk_object_unref(GTK_OBJECT(iterator)); + for (i = 0; i < E_CARD_SIMPLE_ADDRESS_ID_LAST; i ++) { + if (simple->address[i]) { + simple->address[i]->flags = addr_correspondences[i]; + e_card_list_append(address_list, simple->address[i]); + e_card_address_label_free(simple->address[i]); + simple->address[i] = NULL; + } + } + } +} + +ECardPhone *e_card_simple_get_phone (ECardSimple *simple, + ECardSimplePhoneId id) +{ + return simple->phone[id]; +} + +char *e_card_simple_get_email (ECardSimple *simple, + ECardSimpleEmailId id) +{ + return simple->email[id]; +} + +ECardAddrLabel *e_card_simple_get_address (ECardSimple *simple, + ECardSimpleAddressId id) +{ + return simple->address[id]; +} + +void e_card_simple_set_phone (ECardSimple *simple, + ECardSimplePhoneId id, + ECardPhone *phone) +{ + if (simple->phone[id]) + e_card_phone_free(simple->phone[id]); + simple->phone[id] = e_card_phone_copy(phone); +} + +void e_card_simple_set_email (ECardSimple *simple, + ECardSimpleEmailId id, + char *email) +{ + if (simple->email[id]) + g_free(simple->email[id]); + simple->email[id] = g_strdup(email); +} + +void e_card_simple_set_address (ECardSimple *simple, + ECardSimpleAddressId id, + ECardAddrLabel *address) +{ + if (simple->address[id]) + e_card_address_label_free(simple->address[id]); + simple->address[id] = e_card_address_label_copy(address); +} diff --git a/addressbook/backend/ebook/e-card-simple.h b/addressbook/backend/ebook/e-card-simple.h new file mode 100644 index 0000000000..e039b55340 --- /dev/null +++ b/addressbook/backend/ebook/e-card-simple.h @@ -0,0 +1,115 @@ +/* -*- Mode: C; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 8 -*- */ +/* + * Authors: + * Chris Lahey + * Arturo Espinosa + * Nat Friedman (nat@helixcode.com) + * + * Copyright (C) 2000 Helix Code, Inc. + * Copyright (C) 1999 The Free Software Foundation + */ + +#ifndef __E_CARD_SIMPLE_H__ +#define __E_CARD_SIMPLE_H__ + +#include +#include +#include +#include +#include +#include + +#define E_TYPE_CARD_SIMPLE (e_card_simple_get_type ()) +#define E_CARD_SIMPLE(obj) (GTK_CHECK_CAST ((obj), E_TYPE_CARD_SIMPLE, ECardSimple)) +#define E_CARD_SIMPLE_CLASS(klass) (GTK_CHECK_CLASS_CAST ((klass), E_TYPE_CARD_SIMPLE, ECardSimpleClass)) +#define E_IS_CARD_SIMPLE(obj) (GTK_CHECK_TYPE ((obj), E_TYPE_CARD_SIMPLE)) +#define E_IS_CARD_SIMPLE_CLASS(klass) (GTK_CHECK_CLASS_TYPE ((klass), E_TYPE_CARD_SIMPLE)) + +typedef enum _ECardSimplePhoneId ECardSimplePhoneId; +typedef enum _ECardSimpleEmailId ECardSimpleEmailId; +typedef enum _ECardSimpleAddressId ECardSimpleAddressId; + +enum _ECardSimplePhoneId { + E_CARD_SIMPLE_PHONE_ID_ASSISTANT, + E_CARD_SIMPLE_PHONE_ID_BUSINESS, + E_CARD_SIMPLE_PHONE_ID_BUSINESS_2, + E_CARD_SIMPLE_PHONE_ID_BUSINESS_FAX, + E_CARD_SIMPLE_PHONE_ID_CALLBACK, + E_CARD_SIMPLE_PHONE_ID_CAR, + E_CARD_SIMPLE_PHONE_ID_COMPANY, + E_CARD_SIMPLE_PHONE_ID_HOME, + E_CARD_SIMPLE_PHONE_ID_HOME_2, + E_CARD_SIMPLE_PHONE_ID_HOME_FAX, + E_CARD_SIMPLE_PHONE_ID_ISDN, + E_CARD_SIMPLE_PHONE_ID_MOBILE, + E_CARD_SIMPLE_PHONE_ID_OTHER, + E_CARD_SIMPLE_PHONE_ID_OTHER_FAX, + E_CARD_SIMPLE_PHONE_ID_PAGER, + E_CARD_SIMPLE_PHONE_ID_PRIMARY, + E_CARD_SIMPLE_PHONE_ID_RADIO, + E_CARD_SIMPLE_PHONE_ID_TELEX, + E_CARD_SIMPLE_PHONE_ID_TTYTTD, + E_CARD_SIMPLE_PHONE_ID_LAST +}; + +/* We need HOME and WORK email addresses here. */ +enum _ECardSimpleEmailId { + E_CARD_SIMPLE_EMAIL_ID_EMAIL, + E_CARD_SIMPLE_EMAIL_ID_EMAIL_2, + E_CARD_SIMPLE_EMAIL_ID_EMAIL_3, + E_CARD_SIMPLE_EMAIL_ID_LAST +}; + +/* Should this include (BILLING/SHIPPING)? */ +enum _ECardSimpleAddressId { + E_CARD_SIMPLE_ADDRESS_ID_BUSINESS, + E_CARD_SIMPLE_ADDRESS_ID_HOME, + E_CARD_SIMPLE_ADDRESS_ID_OTHER, + E_CARD_SIMPLE_ADDRESS_ID_LAST +}; + +typedef struct _ECardSimple ECardSimple; +typedef struct _ECardSimpleClass ECardSimpleClass; + +struct _ECardSimple { + GtkObject object; + ECard *card; + + ECardPhone *phone[E_CARD_SIMPLE_PHONE_ID_LAST]; + char *email[E_CARD_SIMPLE_EMAIL_ID_LAST]; + ECardAddrLabel *address[E_CARD_SIMPLE_ADDRESS_ID_LAST]; +}; + +struct _ECardSimpleClass { + GtkObjectClass parent_class; +}; + +ECardSimple *e_card_simple_new (ECard *card); +char *e_card_simple_get_id (ECardSimple *simple); +void e_card_simple_set_id (ECardSimple *simple, const gchar *character); +char *e_card_simple_get_vcard (ECardSimple *simple); + +ECardSimple *e_card_simple_duplicate (ECardSimple *simple); + +ECardPhone *e_card_simple_get_phone (ECardSimple *simple, + ECardSimplePhoneId id); +char *e_card_simple_get_email (ECardSimple *simple, + ECardSimpleEmailId id); +ECardAddrLabel *e_card_simple_get_address (ECardSimple *simple, + ECardSimpleAddressId id); +void e_card_simple_set_phone (ECardSimple *simple, + ECardSimplePhoneId id, + ECardPhone *phone); +void e_card_simple_set_email (ECardSimple *simple, + ECardSimpleEmailId id, + char *email); +void e_card_simple_set_address (ECardSimple *simple, + ECardSimpleAddressId id, + ECardAddrLabel *address); + +void e_card_simple_sync_card (ECardSimple *simple); + +/* Standard Gtk function */ +GtkType e_card_simple_get_type (void); + +#endif /* ! __E_CARD_SIMPLE_H__ */ -- cgit v1.2.3