#include <QtCore/QDebug>
#include "contactmanager.h"
-namespace
-{
- const int COUNTRY_CODES[] = {358, 45, 46, 47, 354};
- const int NUM_OF_CODES = 5;
-}
ContactManager::ContactManager(): book_(0)
{
EBookQuery* query;
GList *g_contacts;
- QString copy(number);
- QString clean = removeCountryCode(copy);
+ // Just check the last 7 digits
+ QString clean = number.right(7);
query = e_book_query_any_field_contains(clean.toLatin1());
EContact* newContact = e_contact_new();
GError* error = NULL;
- //EContactAddress* addr = new EContactAddress;
+ EContactAddress* addr = NULL;
if(!contact.name.isEmpty())
{
- char* name = contact.name.toLatin1().data();
+ char* name = contact.name.toUtf8().data();
e_contact_set(newContact, E_CONTACT_FULL_NAME, (gpointer)name);
}
- // Doesn't work for some reason
- /*if(!contact.city.isEmpty() || !contact.street.isEmpty())
- {
- addr->street = contact.street.toLatin1().data();
- addr->locality = contact.city.toLatin1().data();
- e_contact_set(newContact, E_CONTACT_ADDRESS_HOME, (gpointer)addr);
- }*/
+ if(!contact.city.isEmpty() || !contact.street.isEmpty())
+ {
+ addr = g_new0 (EContactAddress, 1);
+ addr->address_format = g_strdup("");
+ addr->po = g_strdup(contact.streetNumber.toUtf8().data());
+ addr->ext = g_strdup("");
+ addr->region = g_strdup("");
+ addr->code = g_strdup(contact.zipCode.toUtf8().data());
+ addr->country = g_strdup(contact.country.toUtf8().data());
+ addr->street = g_strdup(contact.street.toUtf8().data());
+ addr->locality = g_strdup(contact.city.toUtf8().data());
+ e_contact_set(newContact, E_CONTACT_ADDRESS_OTHER, (gpointer)addr);
+ }
if(!contact.number.isEmpty())
{
- char* number = contact.number.toLatin1().data();
- e_contact_set(newContact, E_CONTACT_PHONE_HOME, (gpointer)number);
+ char* number = contact.number.toUtf8().data();
+ e_contact_set(newContact, E_CONTACT_PHONE_OTHER, (gpointer)number);
}
+ bool ret = true;
+
if(!e_book_add_contact(book_, newContact, &error))
{
- qDebug() << "Couldn't add contact: %s" << error->message;
+ qDebug() << "Couldn't add contact: " << error->message;
g_error_free(error);
- return false;
+ ret = false;
}
- return true;
+ if(addr)
+ {
+ e_contact_address_free(addr);
+ }
+
+ return ret;
}
bool ContactManager::load()
}
-QString& ContactManager::removeCountryCode(QString& number)
-{
- if(number.isEmpty())
- {
- return number;
- }
-
- if(number.at(0) == '0')
- {
- return number.remove(0, 1);
- }
- else if(number.at(0) != '+')
- {
- return number;
- }
-
- static QRegExp countryCodeCleaner;
- static bool countryCodeCleanerLoaded = false;
-
- if(!countryCodeCleanerLoaded)
- {
- QString match = "";
-
- for(int i = 0; i < NUM_OF_CODES; i++)
- {
- if(i > 0)
- {
- match += "|";
- }
-
- match += "\\+" + QString::number(COUNTRY_CODES[i]);
- }
-
- countryCodeCleaner = QRegExp("^(" + match + ")");
- countryCodeCleanerLoaded = true;
- }
-
- return number.replace(countryCodeCleaner, "");
-}
-