ContactEditorData.FullNamesListTokens.insert(std::make_pair(0, wxT("")));
}
-
- /*ContactData.Add(wxT("BEGIN"), wxT("VCARD"), FALSE);
- ContactData.Add(wxT("VERSION"), wxT("4.0"), FALSE);
-
- // Setup the version string.
-
- strValue.Append(wxT("-//Xestia//Address Book Version "));
- strValue.Append(wxT(XSDAB_VERSION));
- strValue.Append(wxT("//KW"));
-
- ContactData.Add(wxT("PRODID"), strValue, FALSE);
-
- // Process the REV property.
-
- wxDateTime DateTimeSave;
- DateTimeSave = DateTimeSave.SetToCurrent();
- wxString DateTimeSaveValue;
-
- DateTimeSaveValue += wxString::Format("%04i", DateTimeSave.GetYear());
- DateTimeSaveValue += wxString::Format("%02i", (DateTimeSave.GetMonth() + 1));
- DateTimeSaveValue += wxString::Format("%02i", DateTimeSave.GetDay());
- DateTimeSaveValue += "T";
- DateTimeSaveValue += wxString::Format("%02i", DateTimeSave.GetHour());
- DateTimeSaveValue += wxString::Format("%02i", DateTimeSave.GetMinute());
- DateTimeSaveValue += wxString::Format("%02i", DateTimeSave.GetSecond());
-
- if (!ContactEditorData.RevisionTokens.IsEmpty()){
-
- ContactData.AddRaw("REV;" + ContactEditorData.RevisionTokens, DateTimeSaveValue);
-
- } else {
-
- ContactData.AddRaw("REV", DateTimeSaveValue);
-
- }
-
- // Process the XML properties.
-
- for (std::map<int,wxString>::iterator iter = ContactEditorData.XMLList.begin();
- iter != ContactEditorData.XMLList.end(); ++iter){
-
- wxString strOrigValue;
-
- strOrigValue = ContactEditorData.XMLList.find(iter->first)->second;
-
- ResetUnusedString(&strOrigValue);
-
- ProcessSaveData(wxT("XML"), &strValue2, &boolValue2, &boolValue,
- &iter, &strOrigValue, &ContactData,
- wxT("ALTID"), &ContactEditorData.XMLListAltID );
-
- ResetSaveProcessData();
-
- }
-
- // Process the CLIENTPIDMAP properties.
-
- for (std::map<int,wxString>::iterator iter = ContactEditorData.ClientPIDList.begin();
- iter != ContactEditorData.ClientPIDList.end(); ++iter){
-
- wxString strOrigValue;
-
- strOrigValue = ContactEditorData.ClientPIDList.find(iter->first)->second;
-
- ResetUnusedString(&strOrigValue);
-
- ProcessSaveData(wxT("CLIENTPIDMAP"), &strValue2, &boolValue2, &boolValue,
- &iter, &strOrigValue, &ContactData,
- wxT(""), &ContactEditorData.ClientPIDListTokens );
-
- ResetSaveProcessData();
-
- }
-
- // Process the SOURCE properties.
-
- for (std::map<int,wxString>::iterator iter = ContactEditorData.SourceList.begin();
- iter != ContactEditorData.SourceList.end(); ++iter){
-
- wxString strOrigValue;
-
- strOrigValue = ContactEditorData.SourceList.find(iter->first)->second;
-
- ResetUnusedString(&strOrigValue);
-
- ProcessSaveData(wxT("SOURCE"), &strValue2, &boolValue2, &boolValue,
- &iter, &strOrigValue, &ContactData,
- wxT("ALTID"), &ContactEditorData.SourceListAltID,
- wxT("PID"), &ContactEditorData.SourceListPID,
- wxT("TYPE"), &ContactEditorData.SourceListType,
- wxT("PREF"), &ContactEditorData.SourceListPref,
- wxT("MEDIATYPE"), &ContactEditorData.SourceListMediatype,
- wxT(""), &ContactEditorData.SourceListTokens );
-
- ResetSaveProcessData();
-
- }
-
- // Setup the name.
-
- strValue.Clear();
-
- // Setup the name field.
-
- strValue = txtSurname->GetValue() + wxT(";") +
- txtForename->GetValue() + wxT(";") +
- txtOtherNames->GetValue() + wxT(";") +
- txtTitle->GetValue() + wxT(";") +
- txtSuffix->GetValue();
-
- strValue2 = ContactData.Convert(cmbDisplayAs->GetValue(), FALSE);
- strValue2.Trim();
-
- if (ContactEditorData.NameTokens.IsEmpty()){
-
- ContactData.Add(wxT("N;SORT-AS=\"") + strValue2 + wxT("\""), strValue, FALSE);
-
- } else {
-
- ContactData.Add(wxT("N;SORT-AS=\"") + strValue2 + wxT("\";") + ContactEditorData.NameTokens, strValue, FALSE);
-
- }
-
- if (cmbType->GetCurrentSelection() == 1){
-
- ContactData.AddRaw(wxT("KIND"), wxT("individual"));
-
- } else if (cmbType->GetCurrentSelection() == 2){
-
- ContactData.AddRaw(wxT("KIND"), wxT("group"));
-
- // Go through each of the members and write them out.
-
- for (std::map<int, wxString>::iterator itemiter = ContactEditorData.GroupsList.begin();
- itemiter != ContactEditorData.GroupsList.end(); ++itemiter){
-
- ContactData.Add(wxT("MEMBER:urn:uuid"), itemiter->second, FALSE);
-
- }
-
- } else if (cmbType->GetCurrentSelection() == 3){
-
- ContactData.AddRaw(wxT("KIND"), wxT("org"));
-
- } else if (cmbType->GetCurrentSelection() == 4){
-
- ContactData.AddRaw(wxT("KIND"), wxT("location"));
-
- }
-
-
- // Setup the nicknames (General, Home & Business).
-
- strValue.Clear();
- strValue2.Clear();
- strValue3.Clear();
-
- boolValue = FALSE;
- boolValue2 = FALSE;
- intValue2 = 0;
- intValue = 0;
-
- // Setup the gender.
-
- if (cmbGender->GetCurrentSelection() != 0){
-
- switch(cmbGender->GetCurrentSelection()){
-
- case 1:
-
- strValue = wxT("M");
- break;
-
- case 2:
-
- strValue = wxT("F");
- break;
-
- case 3:
-
- strValue = wxT("O");
- break;
-
- case 4:
-
- strValue = wxT("N");
- break;
-
- case 5:
-
- strValue = wxT("U");
- break;
-
- }
-
- }
-
- if (!txtGenderDescription->IsEmpty()){
-
- strValue2 = txtGenderDescription->GetValue();
-
- }
-
- if (!strValue.IsEmpty() || !strValue2.IsEmpty()){
-
- EscapeString(&strValue2, FALSE);
-
- if (!ContactEditorData.GenderTokens.IsEmpty()){
-
- if (!strValue2.IsEmpty()){
-
- ContactData.AddRaw(wxT("GENDER;") + ContactEditorData.GenderTokens, strValue + wxT(";") + strValue2);
-
- } else {
-
- ContactData.AddRaw(wxT("GENDER;") + ContactEditorData.GenderTokens, strValue);
-
- }
-
- } else {
-
- if (!strValue2.IsEmpty()){
-
- ContactData.AddRaw(wxT("GENDER"), strValue + wxT(";") + strValue2);
-
- } else {
-
- ContactData.AddRaw(wxT("GENDER"), strValue);
-
- }
-
- }
-
- }
-
- ResetSaveProcessData();
-
- // Build the values for the BDAY property.
-
- // ALTID
-
- if (!ContactEditorData.BirthdayAltID.IsEmpty()){
-
- wxString DataValue;
- DataValue = ContactEditorData.BirthdayAltID;
-
- EscapeString(&DataValue, FALSE);
-
- strValue3.Append("ALTID=");
- strValue3.Append(DataValue);
-
- boolValue2 = TRUE;
-
- }
-
- // CALSCALE.
-
- if (!ContactEditorData.BirthdayCalScale.IsEmpty()){
-
- wxString DataValue;
- DataValue = ContactEditorData.BirthdayCalScale;
-
- EscapeString(&DataValue, FALSE);
-
- if (boolValue2 == TRUE){
-
- strValue3.Append(";");
-
- }
-
- strValue3.Append("CALSCALE=");
- strValue3.Append(DataValue);
-
- boolValue2 = TRUE;
-
- }
-
- // Extra tokens.
-
- if (!ContactEditorData.BirthdayTokens.IsEmpty()){
-
- wxString DataValue;
- DataValue = ContactEditorData.BirthdayTokens;
-
- EscapeString(&DataValue, FALSE);
-
- if (boolValue2 == TRUE){
-
- strValue3.Append(";");
-
- }
-
- strValue3.Append(DataValue);
-
- }
-
- // Write the BDAY property.
-
- if (!txtBirthday->IsEmpty()){
-
- if (!txtBirthday->GetValue().IsEmpty()){
-
- strValue = txtBirthday->GetValue();
-
- if (!strValue3.IsEmpty()){
-
- ContactData.AddRaw("BDAY;VALUE=text;" + strValue3, strValue);
-
- } else {
-
- ContactData.AddRaw("BDAY;VALUE=text", strValue);
-
- }
-
- }
-
- } else {
-
- // Deal with date.
-
- // Get Day, Month & Year.
-
- wxDateTime BirthdayDate;
- wxDateTime::Month BirthdayMonth;
- int BirthdayDay;
- int BirthdayYear;
- wxString DataBeforeT;
- wxString DataAfterT;
- wxString FinalBirthdayString;
- bool ProcessDataAfterT = FALSE;
-
- BirthdayDate = dapBirthday->GetValue();
-
- if (BirthdayDate.IsValid()){
-
- BirthdayDay = BirthdayDate.GetDay();
- BirthdayMonth = BirthdayDate.GetMonth();
- BirthdayYear = BirthdayDate.GetYear();
-
- // Look for T and replace data before this.
-
- wxStringTokenizer wSTDate(ContactEditorData.Birthday, wxT("T"));
-
- while (wSTDate.HasMoreTokens()){
-
- if (ProcessDataAfterT == FALSE){
-
- DataBeforeT = wSTDate.GetNextToken();
- ProcessDataAfterT = TRUE;
-
- } else {
-
- DataAfterT = wSTDate.GetNextToken();
- break;
-
- }
-
- }
-
- // If there is not T then replace altogether.
-
- wxString FinalBirthdayDay;
- wxString FinalBirthdayMonth;
- wxString FinalBirthdayYear;
-
- if (BirthdayDay < 10){
-
- FinalBirthdayDay = wxT("0") + wxString::Format(wxT("%i"), BirthdayDay);
-
- } else {
-
- FinalBirthdayDay = wxString::Format(wxT("%i"), BirthdayDay);
-
- }
-
- if (((int)BirthdayMonth + 1) < 10){
-
- FinalBirthdayMonth = wxT("0") + wxString::Format(wxT("%i"), ((int)BirthdayMonth + 1));
-
- } else {
-
- FinalBirthdayMonth = wxString::Format(wxT("%i"), ((int)BirthdayMonth + 1));
-
- }
-
- if (BirthdayYear == 0){
-
- FinalBirthdayYear = wxT("--");
-
- } else {
-
- FinalBirthdayYear = wxString::Format(wxT("%i"), BirthdayYear);
-
- }
-
- if (!DataAfterT.IsEmpty()){
-
- FinalBirthdayString = FinalBirthdayYear + FinalBirthdayMonth + FinalBirthdayDay + wxT("T") + DataAfterT;
-
- } else {
-
- FinalBirthdayString = FinalBirthdayYear + FinalBirthdayMonth + FinalBirthdayDay;
-
- }
-
- if (!FinalBirthdayString.IsEmpty() || !strValue3.IsEmpty()){
-
- if (!strValue3.IsEmpty()){
-
- EscapeString(&strValue2, FALSE);
- EscapeString(&strValue, FALSE);
-
- ContactData.AddRaw(wxT("BDAY;") + strValue3, FinalBirthdayString);
-
- } else {
-
- EscapeString(&strValue, FALSE);
-
- ContactData.AddRaw(wxT("BDAY"), FinalBirthdayString);
-
- }
-
- }
-
- }
-
- }
-
- ResetSaveProcessData();
-
- // Build the values for the ANNIVERSARY property.
-
- // ALTID
-
- if (!ContactEditorData.AnniversaryAltID.IsEmpty()){
-
- wxString DataValue;
- DataValue = ContactEditorData.AnniversaryAltID;
-
- EscapeString(&DataValue, FALSE);
-
- strValue3.Append("ALTID=");
- strValue3.Append(DataValue);
-
- boolValue2 = TRUE;
-
- }
-
- // CALSCALE.
-
- if (!ContactEditorData.AnniversaryCalScale.IsEmpty()){
-
- wxString DataValue;
- DataValue = ContactEditorData.AnniversaryCalScale;
-
- EscapeString(&DataValue, FALSE);
-
- if (boolValue2 == TRUE){
-
- strValue3.Append(";");
-
- }
-
- strValue3.Append("CALSCALE=");
- strValue3.Append(DataValue);
-
- boolValue2 = TRUE;
-
- }
-
- // Extra tokens.
-
- if (!ContactEditorData.AnniversaryTokens.IsEmpty()){
-
- wxString DataValue;
- DataValue = ContactEditorData.AnniversaryTokens;
-
- EscapeString(&DataValue, FALSE);
-
- if (boolValue2 == TRUE){
-
- strValue3.Append(";");
-
- }
-
- strValue3.Append(DataValue);
-
- }
-
- // Write the ANNIVERSARY property.
-
- if (!txtAnniversary->IsEmpty()){
-
- if (!txtAnniversary->GetValue().IsEmpty()){
-
- strValue = txtAnniversary->GetValue();
-
- if (!strValue3.IsEmpty()){
-
- ContactData.AddRaw("ANNIVERSARY;VALUE=text;" + strValue3, strValue);
-
- } else {
-
- ContactData.AddRaw("ANNIVERSARY;VALUE=text", strValue);
-
- }
-
- }
-
- } else {
-
- // Look for T and replace data before this.
-
- // Get Day, Month & Year.
-
- wxDateTime AnniversaryDate;
- wxDateTime::Month AnniversaryMonth;
- int AnniversaryDay;
- int AnniversaryYear;
- wxString DataBeforeT;
- wxString DataAfterT;
- wxString FinalAnniversaryString;
- bool ProcessDataAfterT = FALSE;
-
- AnniversaryDate = dapAnniversary->GetValue();
-
- if (AnniversaryDate.IsValid()){
-
- AnniversaryDay = AnniversaryDate.GetDay();
- AnniversaryMonth = AnniversaryDate.GetMonth();
- AnniversaryYear = AnniversaryDate.GetYear();
-
- // Look for T and replace data before this.
-
- wxStringTokenizer wSTDate(ContactEditorData.Anniversary, wxT("T"));
-
- while (wSTDate.HasMoreTokens()){
-
- if (ProcessDataAfterT == FALSE){
-
- DataBeforeT = wSTDate.GetNextToken();
- ProcessDataAfterT = TRUE;
-
- } else {
-
- DataAfterT = wSTDate.GetNextToken();
- break;
-
- }
-
- }
-
- // If there is not T then replace altogether.
-
- wxString FinalAnniversaryDay;
- wxString FinalAnniversaryMonth;
- wxString FinalAnniversaryYear;
-
- if (AnniversaryDay < 10){
-
- FinalAnniversaryDay = wxT("0") + wxString::Format(wxT("%i"), AnniversaryDay);
-
- } else {
-
- FinalAnniversaryDay = wxString::Format(wxT("%i"), AnniversaryDay);
-
- }
-
- if (((int)AnniversaryMonth + 1) < 10){
-
- FinalAnniversaryMonth = wxT("0") + wxString::Format(wxT("%i"), ((int)AnniversaryMonth + 1));
-
- } else {
-
- FinalAnniversaryMonth = wxString::Format(wxT("%i"), ((int)AnniversaryMonth + 1));
-
- }
-
- if (AnniversaryYear == 0){
-
- FinalAnniversaryYear = wxT("--");
-
- } else {
-
- FinalAnniversaryYear = wxString::Format(wxT("%i"), AnniversaryYear);
-
- }
-
- if (!DataAfterT.IsEmpty()){
-
- FinalAnniversaryString = FinalAnniversaryYear + FinalAnniversaryMonth + FinalAnniversaryDay + wxT("T") + DataAfterT;
-
- } else {
-
- FinalAnniversaryString = FinalAnniversaryYear + FinalAnniversaryMonth + FinalAnniversaryDay;
-
- }
-
- if (!FinalAnniversaryString.IsEmpty() || !strValue3.IsEmpty()){
-
- if (!strValue3.IsEmpty()){
-
- EscapeString(&strValue2, FALSE);
- EscapeString(&strValue, FALSE);
-
- ContactData.AddRaw(wxT("ANNIVERSARY;") + strValue3, FinalAnniversaryString);
-
- } else {
-
- EscapeString(&strValue, FALSE);
-
- ContactData.AddRaw(wxT("ANNIVERSARY"), FinalAnniversaryString);
-
- }
-
- }
-
- }
-
- }
-
- // Setup the addresses (General, Home, Business).
-
- ResetSaveProcessData();
-
- for (std::map<int,wxString>::iterator iter = ContactEditorData.GeneralAddressList.begin();
- iter != ContactEditorData.GeneralAddressList.end(); ++iter){
-
- int intSeekValue = iter->first;
-
- wxString strAddressString;
- wxString strAddressFinalValue;
- std::map<int, wxString>::iterator iterValue;
-
- strAddressString.Append(wxT(";;"));
-
- // Get Address
-
- iterValue = ContactEditorData.GeneralAddressList.find(intSeekValue);
- strAddressFinalValue = iterValue->second;
- ProcessCaptureStrings(&strAddressFinalValue);
- strAddressString.Append(strAddressFinalValue + wxT(";"));
- strAddressFinalValue.Clear();
-
- // Get Town
-
- iterValue = ContactEditorData.GeneralAddressListTown.find(intSeekValue);
- strAddressFinalValue = iterValue->second;
- ProcessCaptureStrings(&strAddressFinalValue);
- strAddressString.Append(strAddressFinalValue + wxT(";"));
- strAddressFinalValue.Clear();
-
- // Get County
-
- iterValue = ContactEditorData.GeneralAddressListCounty.find(intSeekValue);
- strAddressFinalValue = iterValue->second;
- ProcessCaptureStrings(&strAddressFinalValue);
- strAddressString.Append(strAddressFinalValue + wxT(";"));
- strAddressFinalValue.Clear();
-
- // Get Post Code
-
- iterValue = ContactEditorData.GeneralAddressListPostCode.find(intSeekValue);
- strAddressFinalValue = iterValue->second;
- ProcessCaptureStrings(&strAddressFinalValue);
- strAddressString.Append(strAddressFinalValue + wxT(";"));
- strAddressFinalValue.Clear();
-
- // Get Country
-
- iterValue = ContactEditorData.GeneralAddressListCountry.find(intSeekValue);
- strAddressFinalValue = iterValue->second;
- ProcessCaptureStrings(&strAddressFinalValue);
- strAddressString.Append(strAddressFinalValue);
- strAddressFinalValue.Clear();
-
- ProcessSaveData(wxT("ADR"), &strValue2, &boolValue2, &boolValue,
- &iter, &strAddressString, &ContactData,
- wxT("LABEL"), &ContactEditorData.GeneralAddressListLabel,
- wxT("LANGUAGE"), &ContactEditorData.GeneralAddressListLang,
- wxT("ALTID"), &ContactEditorData.GeneralAddressListAltID,
- wxT("PID"), &ContactEditorData.GeneralAddressListPID,
- wxT("GEO"), &ContactEditorData.GeneralAddressListGeo,
- wxT("TZ"), &ContactEditorData.GeneralAddressListTimezone,
- wxT("MEDIATYPE"), &ContactEditorData.GeneralAddressListMediatype,
- wxT("PREF"), &ContactEditorData.GeneralAddressListPref,
- wxT(""), &ContactEditorData.GeneralAddressListTokens );
-
- ResetSaveProcessData();
-
- }
-
- ResetSaveProcessData();
-
- for (std::map<int,wxString>::iterator iter = ContactEditorData.HomeAddressList.begin();
- iter != ContactEditorData.HomeAddressList.end(); ++iter){
-
- int intSeekValue = iter->first;
-
- wxString strAddressString;
- wxString strAddressFinalValue;
- std::map<int, wxString>::iterator iterValue;
-
- strAddressString.Append(wxT(";;"));
-
- // Get Address
-
- iterValue = ContactEditorData.HomeAddressList.find(intSeekValue);
- strAddressFinalValue = iterValue->second;
- ProcessCaptureStrings(&strAddressFinalValue);
- strAddressString.Append(strAddressFinalValue + wxT(";"));
-
- // Get Town
-
- iterValue = ContactEditorData.HomeAddressListTown.find(intSeekValue);
- strAddressFinalValue = iterValue->second;
- ProcessCaptureStrings(&strAddressFinalValue);
- strAddressString.Append(strAddressFinalValue + wxT(";"));
-
- // Get County
-
- iterValue = ContactEditorData.HomeAddressListCounty.find(intSeekValue);
- strAddressFinalValue = iterValue->second;
- ProcessCaptureStrings(&strAddressFinalValue);
- strAddressString.Append(strAddressFinalValue + wxT(";"));
-
- // Get Post Code
-
- iterValue = ContactEditorData.HomeAddressListPostCode.find(intSeekValue);
- strAddressFinalValue = iterValue->second;
- ProcessCaptureStrings(&strAddressFinalValue);
- strAddressString.Append(strAddressFinalValue + wxT(";"));
-
- // Get Country
-
- iterValue = ContactEditorData.HomeAddressListCountry.find(intSeekValue);
- strAddressFinalValue = iterValue->second;
- ProcessCaptureStrings(&strAddressFinalValue);
- strAddressString.Append(strAddressFinalValue);
-
- ProcessSaveData(wxT("ADR;TYPE=home"), &strValue2, &boolValue2, &boolValue,
- &iter, &strAddressString, &ContactData,
- wxT("LABEL"), &ContactEditorData.HomeAddressListLabel,
- wxT("LANGUAGE"), &ContactEditorData.HomeAddressListLang,
- wxT("ALTID"), &ContactEditorData.HomeAddressListAltID,
- wxT("PID"), &ContactEditorData.HomeAddressListPID,
- wxT("GEO"), &ContactEditorData.HomeAddressListGeo,
- wxT("TZ"), &ContactEditorData.HomeAddressListTimezone,
- wxT("MEDIATYPE"), &ContactEditorData.HomeAddressListMediatype,
- wxT("PREF"), &ContactEditorData.HomeAddressListPref,
- wxT(""), &ContactEditorData.HomeAddressListTokens );
-
- ResetSaveProcessData();
-
- }
-
- ResetSaveProcessData();
-
- for (std::map<int,wxString>::iterator iter = ContactEditorData.BusinessAddressList.begin();
- iter != ContactEditorData.BusinessAddressList.end(); ++iter){
-
- int intSeekValue = iter->first;
-
- wxString strAddressString;
- wxString strAddressFinalValue;
- std::map<int, wxString>::iterator iterValue;
-
- strAddressString.Append(wxT(";;"));
-
- // Get Address
-
- iterValue = ContactEditorData.BusinessAddressList.find(intSeekValue);
- strAddressFinalValue = iterValue->second;
- ProcessCaptureStrings(&strAddressFinalValue);
-
- strAddressString.Append(strAddressFinalValue + wxT(";"));
-
- // Get Town
-
- iterValue = ContactEditorData.BusinessAddressListTown.find(intSeekValue);
- strAddressFinalValue = iterValue->second;
- ProcessCaptureStrings(&strAddressFinalValue);
-
- strAddressString.Append(strAddressFinalValue + wxT(";"));
-
- // Get County
-
- iterValue = ContactEditorData.BusinessAddressListCounty.find(intSeekValue);
- strAddressFinalValue = iterValue->second;
- ProcessCaptureStrings(&strAddressFinalValue);
-
- strAddressString.Append(strAddressFinalValue + wxT(";"));
-
- // Get Post Code
-
- iterValue = ContactEditorData.BusinessAddressListPostCode.find(intSeekValue);
- strAddressFinalValue = iterValue->second;
- ProcessCaptureStrings(&strAddressFinalValue);
-
- strAddressString.Append(strAddressFinalValue + wxT(";"));
-
- // Get Country
-
- iterValue = ContactEditorData.BusinessAddressListCountry.find(intSeekValue);
- strAddressFinalValue = iterValue->second;
- ProcessCaptureStrings(&strAddressFinalValue);
-
- strAddressString.Append(strAddressFinalValue);
-
- ProcessSaveData(wxT("ADR;TYPE=work"), &strValue2, &boolValue2, &boolValue,
- &iter, &strAddressString, &ContactData,
- wxT("LABEL"), &ContactEditorData.BusinessAddressListLabel,
- wxT("LANGUAGE"), &ContactEditorData.BusinessAddressListLang,
- wxT("ALTID"), &ContactEditorData.BusinessAddressListAltID,
- wxT("PID"), &ContactEditorData.BusinessAddressListPID,
- wxT("GEO"), &ContactEditorData.BusinessAddressListGeo,
- wxT("TZ"), &ContactEditorData.BusinessAddressListTimezone,
- wxT("MEDIATYPE"), &ContactEditorData.BusinessAddressListMediatype,
- wxT("PREF"), &ContactEditorData.BusinessAddressListPref,
- wxT(""), &ContactEditorData.BusinessAddressListTokens );
-
- ResetSaveProcessData();
-
- }
-
- // Sort out nicknames (if any).
-
- for (std::map<int,wxString>::iterator iter = ContactEditorData.GeneralNicknamesList.begin();
- iter != ContactEditorData.GeneralNicknamesList.end(); ++iter){
-
- intValue2 = iter->first;
-
- // Process Alternative ID.
-
- ProcessSaveData(wxT("NICKNAME"), &strValue2, &boolValue2, &boolValue,
- &iter, &ContactEditorData.GeneralNicknamesList, &ContactData,
- wxT("LANGUAGE"), &ContactEditorData.GeneralNicknamesListLanguage,
- wxT("ALTID"), &ContactEditorData.GeneralNicknamesListAltID,
- wxT("PID"), &ContactEditorData.GeneralNicknamesListPID,
- wxT("PREF"), &ContactEditorData.GeneralNicknamesListPref,
- wxT(""), &ContactEditorData.GeneralNicknamesListTokens );
-
- ResetSaveProcessData();
-
- }
-
- ResetSaveProcessData();
-
- for (std::map<int,wxString>::iterator iter = ContactEditorData.HomeNicknamesList.begin();
- iter != ContactEditorData.HomeNicknamesList.end(); ++iter){
-
- ProcessSaveData(wxT("NICKNAME;TYPE=home"), &strValue2, &boolValue2, &boolValue,
- &iter, &ContactEditorData.HomeNicknamesList, &ContactData,
- wxT("LANGUAGE"), &ContactEditorData.HomeNicknamesListLanguage,
- wxT("ALTID"), &ContactEditorData.HomeNicknamesListAltID,
- wxT("PID"), &ContactEditorData.HomeNicknamesListPID,
- wxT("PREF"), &ContactEditorData.HomeNicknamesListPref,
- wxT(""), &ContactEditorData.HomeNicknamesListTokens );
-
- ResetSaveProcessData();
-
- }
-
- ResetSaveProcessData();
-
- for (std::map<int,wxString>::iterator iter = ContactEditorData.BusinessNicknamesList.begin();
- iter != ContactEditorData.BusinessNicknamesList.end(); ++iter){
-
- ProcessSaveData(wxT("NICKNAME;TYPE=work"), &strValue2, &boolValue2, &boolValue,
- &iter, &ContactEditorData.BusinessNicknamesList, &ContactData,
- wxT("LANGUAGE"), &ContactEditorData.BusinessNicknamesListLanguage,
- wxT("ALTID"), &ContactEditorData.BusinessNicknamesListAltID,
- wxT("PID"), &ContactEditorData.BusinessNicknamesListPID,
- wxT("PREF"), &ContactEditorData.BusinessNicknamesListPref,
- wxT(""), &ContactEditorData.BusinessNicknamesListTokens );
-
- ResetSaveProcessData();
-
- }
-
- ResetSaveProcessData();
-
- // Sort out email (general, home and business).
-
- for (std::map<int,wxString>::iterator iter = ContactEditorData.GeneralEmailList.begin();
- iter != ContactEditorData.GeneralEmailList.end(); ++iter){
-
- wxString strAddressFinalValue;
- std::map<int, wxString>::iterator iterValue;
-
- ProcessSaveData(wxT("EMAIL"), &strValue2, &boolValue2, &boolValue,
- &iter, &ContactEditorData.GeneralEmailList, &ContactData,
- wxT("ALTID"), &ContactEditorData.GeneralEmailListAltID,
- wxT("PID"), &ContactEditorData.GeneralEmailListPID,
- wxT("PREF"), &ContactEditorData.GeneralEmailListPref,
- wxT(""), &ContactEditorData.GeneralEmailListTokens );
-
- ResetSaveProcessData();
-
- }
-
- ResetSaveProcessData();
-
- for (std::map<int,wxString>::iterator iter = ContactEditorData.HomeEmailList.begin();
- iter != ContactEditorData.HomeEmailList.end(); ++iter){
-
- ProcessSaveData(wxT("EMAIL;TYPE=home"), &strValue2, &boolValue2, &boolValue,
- &iter, &ContactEditorData.HomeEmailList, &ContactData,
- wxT("ALTID"), &ContactEditorData.HomeEmailListAltID,
- wxT("PID"), &ContactEditorData.HomeEmailListPID,
- wxT("PREF"), &ContactEditorData.HomeEmailListPref,
- wxT(""), &ContactEditorData.HomeEmailListTokens );
-
- ResetSaveProcessData();
-
- }
-
- ResetSaveProcessData();
-
- for (std::map<int,wxString>::iterator iter = ContactEditorData.BusinessEmailList.begin();
- iter != ContactEditorData.BusinessEmailList.end(); ++iter){
-
- ProcessSaveData(wxT("EMAIL;TYPE=work"), &strValue2, &boolValue2, &boolValue,
- &iter, &ContactEditorData.BusinessEmailList, &ContactData,
- wxT("ALTID"), &ContactEditorData.BusinessEmailListAltID,
- wxT("PID"), &ContactEditorData.BusinessEmailListPID,
- wxT("PREF"), &ContactEditorData.BusinessEmailListPref,
- wxT(""), &ContactEditorData.BusinessEmailListTokens );
-
- ResetSaveProcessData();
-
- }
-
- ResetSaveProcessData();
-
- for (std::map<int,wxString>::iterator iter = ContactEditorData.GeneralIMList.begin();
- iter != ContactEditorData.GeneralIMList.end(); ++iter){
-
- intValue2 = iter->first;
-
- wxString strIMFinalValue = iter->second;
-
- ProcessCaptureStrings(&strIMFinalValue);
-
- if (ContactEditorData.GeneralIMListTypeInfo.find(iter->first) !=
- ContactEditorData.GeneralIMListTypeInfo.end()){
-
- std::map<int,wxString>::iterator DataTypeIter = ContactEditorData.GeneralIMListTypeInfo.find(iter->first);
-
- strIMFinalValue.insert(0, ":");
- strIMFinalValue.insert(0, DataTypeIter->second);
-
- } else {
-
- strIMFinalValue.insert(0, "none:");
-
- }
-
- // Process Alternative ID.
-
- ProcessSaveData(wxT("IMPP"), &strValue2, &boolValue2, &boolValue,
- &iter, &strIMFinalValue, &ContactData,
- wxT("ALTID"), &ContactEditorData.GeneralIMListAltID,
- wxT("PID"), &ContactEditorData.GeneralIMListPID,
- wxT("MEDIATYPE"), &ContactEditorData.GeneralIMListMediatype,
- wxT("PREF"), &ContactEditorData.GeneralIMListPref,
- wxT(""), &ContactEditorData.GeneralIMListTokens );
-
- ResetSaveProcessData();
-
- }
-
- ResetSaveProcessData();
-
- for (std::map<int,wxString>::iterator iter = ContactEditorData.HomeIMList.begin();
- iter != ContactEditorData.HomeIMList.end(); ++iter){
-
- wxString strIMFinalValue = iter->second;
-
- ProcessCaptureStrings(&strIMFinalValue);
-
- if (ContactEditorData.HomeIMListTypeInfo.find(iter->first) !=
- ContactEditorData.HomeIMListTypeInfo.end()){
-
- std::map<int,wxString>::iterator DataTypeIter = ContactEditorData.HomeIMListTypeInfo.find(iter->first);
-
- strIMFinalValue.insert(0, ":");
- strIMFinalValue.insert(0, DataTypeIter->second);
-
- } else {
-
- strIMFinalValue.insert(0, "none:");
-
- }
-
- ProcessSaveData(wxT("IMPP;TYPE=home"), &strValue2, &boolValue2, &boolValue,
- &iter, &ContactEditorData.HomeIMList, &ContactData,
- wxT("ALTID"), &ContactEditorData.HomeIMListAltID,
- wxT("PID"), &ContactEditorData.HomeIMListPID,
- wxT("MEDIATYPE"), &ContactEditorData.HomeIMListMediatype,
- wxT("PREF"), &ContactEditorData.HomeIMListPref,
- wxT(""), &ContactEditorData.HomeIMListTokens );
-
- ResetSaveProcessData();
-
- }
-
- ResetSaveProcessData();
-
- for (std::map<int,wxString>::iterator iter = ContactEditorData.BusinessIMList.begin();
- iter != ContactEditorData.BusinessIMList.end(); ++iter){
-
- wxString strIMFinalValue = iter->second;
-
- ProcessCaptureStrings(&strIMFinalValue);
-
- if (ContactEditorData.BusinessIMListTypeInfo.find(iter->first) !=
- ContactEditorData.BusinessIMListTypeInfo.end()){
-
- std::map<int,wxString>::iterator DataTypeIter = ContactEditorData.BusinessIMListTypeInfo.find(iter->first);
-
- strIMFinalValue.insert(0, ":");
- strIMFinalValue.insert(0, DataTypeIter->second);
-
- } else {
-
- strIMFinalValue.insert(0, "none:");
-
- }
-
- ProcessSaveData(wxT("IMPP;TYPE=work"), &strValue2, &boolValue2, &boolValue,
- &iter, &ContactEditorData.BusinessIMList, &ContactData,
- wxT("ALTID"), &ContactEditorData.BusinessIMListAltID,
- wxT("PID"), &ContactEditorData.BusinessIMListPID,
- wxT("MEDIATYPE"), &ContactEditorData.BusinessIMListMediatype,
- wxT("PREF"), &ContactEditorData.BusinessIMListPref,
- wxT(""), &ContactEditorData.BusinessIMListTokens );
-
- ResetSaveProcessData();
-
- }
-
- ResetSaveProcessData();
-
- for (std::map<int,wxString>::iterator iter = ContactEditorData.GeneralTelephoneList.begin();
- iter != ContactEditorData.GeneralTelephoneList.end(); ++iter){
-
- wxString strAddressFinalValue = iter->second;
- int DataID = iter->first;
-
- ProcessCaptureStrings(&strAddressFinalValue);
-
- if (MapDataExists(&DataID, &ContactEditorData.GeneralTelephoneListDataType)){
-
- std::map<int,wxString>::iterator DataTypeIter = ContactEditorData.GeneralTelephoneListDataType.find(iter->first);
-
- strAddressFinalValue.insert(0, ":");
- strAddressFinalValue.insert(0, DataTypeIter->second);
-
- } else {
-
- strAddressFinalValue.insert(0, "tel:");
-
- }
-
- wxString strAddressTypeInfo;
-
- if (MapDataExists(&DataID, &ContactEditorData.GeneralTelephoneListTypeInfo)){
-
- strAddressTypeInfo = ContactEditorData.GeneralTelephoneListTypeInfo.find(iter->first)->second;
-
- }
-
- ProcessSaveData(wxT("TEL"), &strValue2, &boolValue2, &boolValue,
- &iter, &strAddressFinalValue, &ContactData,
- wxT("ALTID"), &ContactEditorData.GeneralTelephoneListAltID,
- wxT("PID"), &ContactEditorData.GeneralTelephoneListPID,
- wxT("TYPE"), &ContactEditorData.GeneralTelephoneListTypeInfo,
- wxT("PREF"), &ContactEditorData.GeneralTelephoneListPref,
- wxT(""), &ContactEditorData.GeneralTelephoneListTokens );
-
- ResetSaveProcessData();
-
- }
-
- ResetSaveProcessData();
-
- for (std::map<int,wxString>::iterator iter = ContactEditorData.HomeTelephoneList.begin();
- iter != ContactEditorData.HomeTelephoneList.end(); ++iter){
-
- wxString strAddressFinalValue = iter->second;
-
- ProcessCaptureStrings(&strAddressFinalValue);
-
- if (ContactEditorData.HomeTelephoneListDataType.find(iter->first) !=
- ContactEditorData.HomeTelephoneListDataType.end()){
-
- std::map<int,wxString>::iterator DataTypeIter = ContactEditorData.HomeTelephoneListDataType.find(iter->first);
-
- strAddressFinalValue.insert(0, ":");
- strAddressFinalValue.insert(0, DataTypeIter->second);
-
- } else {
-
- strAddressFinalValue.insert(0, "tel:");
-
- }
-
- ProcessSaveData(wxT("TEL"), &strValue2, &boolValue2, &boolValue,
- &iter, &strAddressFinalValue, &ContactData,
- wxT("ALTID"), &ContactEditorData.HomeTelephoneListAltID,
- wxT("PID"), &ContactEditorData.HomeTelephoneListPID,
- wxT("TYPE"), &ContactEditorData.HomeTelephoneListTypeInfo,
- wxT("PREF"), &ContactEditorData.HomeTelephoneListPref,
- wxT(""), &ContactEditorData.HomeTelephoneListTokens );
-
- ResetSaveProcessData();
-
- }
-
- ResetSaveProcessData();
-
- for (std::map<int,wxString>::iterator iter = ContactEditorData.BusinessTelephoneList.begin();
- iter != ContactEditorData.BusinessTelephoneList.end(); ++iter){
-
- wxString strAddressFinalValue = iter->second;
-
- ProcessCaptureStrings(&strAddressFinalValue);
-
- if (ContactEditorData.BusinessTelephoneListDataType.find(iter->first) !=
- ContactEditorData.BusinessTelephoneListDataType.end()){
-
- std::map<int,wxString>::iterator DataTypeIter = ContactEditorData.BusinessTelephoneListDataType.find(iter->first);
-
- strAddressFinalValue.insert(0, ":");
- strAddressFinalValue.insert(0, DataTypeIter->second);
-
- } else {
-
- strAddressFinalValue.insert(0, "tel:");
-
- }
-
- ProcessSaveData(wxT("TEL"), &strValue2, &boolValue2, &boolValue,
- &iter, &strAddressFinalValue, &ContactData,
- wxT("ALTID"), &ContactEditorData.BusinessTelephoneListAltID,
- wxT("PID"), &ContactEditorData.BusinessTelephoneListPID,
- wxT("TYPE"), &ContactEditorData.BusinessTelephoneListTypeInfo,
- wxT("PREF"), &ContactEditorData.BusinessTelephoneListPref,
- wxT(""), &ContactEditorData.BusinessTelephoneListTokens );
-
- ResetSaveProcessData();
-
- }
-
- ResetSaveProcessData();
-
- for (std::map<int,wxString>::iterator iter = ContactEditorData.GeneralLanguageList.begin();
- iter != ContactEditorData.GeneralLanguageList.end(); ++iter){
-
- intValue2 = iter->first;
-
- ProcessSaveData(wxT("LANG"), &strValue2, &boolValue2, &boolValue,
- &iter, &ContactEditorData.GeneralLanguageList, &ContactData,
- wxT("ALTID"), &ContactEditorData.GeneralLanguageListAltID,
- wxT("PID"), &ContactEditorData.GeneralLanguageListPID,
- wxT("PREF"), &ContactEditorData.GeneralLanguageListPref,
- wxT(""), &ContactEditorData.GeneralLanguageListTokens );
-
- ResetSaveProcessData();
-
- }
-
- ResetSaveProcessData();
-
- for (std::map<int,wxString>::iterator iter = ContactEditorData.HomeLanguageList.begin();
- iter != ContactEditorData.HomeLanguageList.end(); ++iter){
-
- ProcessSaveData(wxT("LANG;TYPE=home"), &strValue2, &boolValue2, &boolValue,
- &iter, &ContactEditorData.HomeLanguageList, &ContactData,
- wxT("ALTID"), &ContactEditorData.HomeLanguageListAltID,
- wxT("PID"), &ContactEditorData.HomeLanguageListPID,
- wxT("PREF"), &ContactEditorData.HomeLanguageListPref,
- wxT(""), &ContactEditorData.HomeLanguageListTokens );
-
- ResetSaveProcessData();
-
- }
-
- ResetSaveProcessData();
-
- for (std::map<int,wxString>::iterator iter = ContactEditorData.BusinessLanguageList.begin();
- iter != ContactEditorData.BusinessLanguageList.end(); ++iter){
-
- ProcessSaveData(wxT("LANG;TYPE=work"), &strValue2, &boolValue2, &boolValue,
- &iter, &ContactEditorData.BusinessLanguageList, &ContactData,
- wxT("ALTID"), &ContactEditorData.BusinessLanguageListAltID,
- wxT("PID"), &ContactEditorData.BusinessLanguageListPID,
- wxT("PREF"), &ContactEditorData.BusinessLanguageListPref,
- wxT(""), &ContactEditorData.BusinessLanguageListTokens );
-
- ResetSaveProcessData();
-
- }
-
- ResetSaveProcessData();
-
- for (std::map<int,wxString>::iterator iter = ContactEditorData.GeneralTZList.begin();
- iter != ContactEditorData.GeneralTZList.end(); ++iter){
-
- ProcessSaveData(wxT("TZ"), &strValue2, &boolValue2, &boolValue,
- &iter, &ContactEditorData.GeneralTZList, &ContactData,
- wxT("ALTID"), &ContactEditorData.GeneralTZListAltID,
- wxT("PID"), &ContactEditorData.GeneralTZListPID,
- wxT("MEDIATYPE"), &ContactEditorData.GeneralTZListMediatype,
- wxT("PREF"), &ContactEditorData.GeneralTZListPref,
- wxT(""), &ContactEditorData.GeneralTZListTokens );
-
- ResetSaveProcessData();
-
- }
-
- ResetSaveProcessData();
-
- for (std::map<int,wxString>::iterator iter = ContactEditorData.HomeTZList.begin();
- iter != ContactEditorData.HomeTZList.end(); ++iter){
-
- ProcessSaveData(wxT("TZ;TYPE=home"), &strValue2, &boolValue2, &boolValue,
- &iter, &ContactEditorData.HomeTZList, &ContactData,
- wxT("ALTID"), &ContactEditorData.HomeTZListAltID,
- wxT("PID"), &ContactEditorData.HomeTZListPID,
- wxT("MEDIATYPE"), &ContactEditorData.HomeTZListMediatype,
- wxT("PREF"), &ContactEditorData.HomeTZListPref,
- wxT(""), &ContactEditorData.HomeTZListTokens );
-
- ResetSaveProcessData();
-
- }
-
- ResetSaveProcessData();
-
- for (std::map<int,wxString>::iterator iter = ContactEditorData.BusinessTZList.begin();
- iter != ContactEditorData.BusinessTZList.end(); ++iter){
-
- ProcessSaveData(wxT("TZ;TYPE=work"), &strValue2, &boolValue2, &boolValue,
- &iter, &ContactEditorData.BusinessTZList, &ContactData,
- wxT("ALTID"), &ContactEditorData.BusinessTZListAltID,
- wxT("PID"), &ContactEditorData.BusinessTZListPID,
- wxT("MEDIATYPE"), &ContactEditorData.BusinessTZListMediatype,
- wxT("PREF"), &ContactEditorData.BusinessTZListPref,
- wxT(""), &ContactEditorData.BusinessTZListTokens );
-
- ResetSaveProcessData();
-
- }
-
- ResetSaveProcessData();
-
- for (std::map<int,wxString>::iterator iter = ContactEditorData.GeneralGeographyList.begin();
- iter != ContactEditorData.GeneralGeographyList.end(); ++iter){
-
- wxString strGeoFinalValue = iter->second;
-
- ProcessCaptureStrings(&strGeoFinalValue);
-
- if (ContactEditorData.GeneralGeographyListDataType.find(iter->first) !=
- ContactEditorData.GeneralGeographyListDataType.end()){
-
- std::map<int,wxString>::iterator DataTypeIter = ContactEditorData.GeneralGeographyListDataType.find(iter->first);
-
- strGeoFinalValue.insert(0, ":");
- strGeoFinalValue.insert(0, DataTypeIter->second);
-
- } else {
-
- strGeoFinalValue.insert(0, "geo:");
-
- }
-
- ProcessSaveData(wxT("GEO"), &strValue2, &boolValue2, &boolValue,
- &iter, &strGeoFinalValue, &ContactData,
- wxT("ALTID"), &ContactEditorData.GeneralGeographyListAltID,
- wxT("PID"), &ContactEditorData.GeneralGeographyListPID,
- wxT("MEDIATYPE"), &ContactEditorData.GeneralGeographyListMediatype,
- wxT("PREF"), &ContactEditorData.GeneralGeographyListPref,
- wxT(""), &ContactEditorData.GeneralGeographyListTokens );
-
- ResetSaveProcessData();
-
- }
-
- ResetSaveProcessData();
-
- for (std::map<int,wxString>::iterator iter = ContactEditorData.HomeGeographyList.begin();
- iter != ContactEditorData.HomeGeographyList.end(); ++iter){
-
- wxString strGeoFinalValue = iter->second;
-
- ProcessCaptureStrings(&strGeoFinalValue);
-
- if (ContactEditorData.HomeGeographyListDataType.find(iter->first) !=
- ContactEditorData.HomeGeographyListDataType.end()){
-
- std::map<int,wxString>::iterator DataTypeIter = ContactEditorData.HomeGeographyListDataType.find(iter->first);
-
- strGeoFinalValue.insert(0, ":");
- strGeoFinalValue.insert(0, DataTypeIter->second);
-
- } else {
-
- strGeoFinalValue.insert(0, "geo:");
-
- }
-
- ProcessSaveData(wxT("GEO;TYPE=home"), &strValue2, &boolValue2, &boolValue,
- &iter, &strGeoFinalValue, &ContactData,
- wxT("ALTID"), &ContactEditorData.HomeGeographyListAltID,
- wxT("PID"), &ContactEditorData.HomeGeographyListPID,
- wxT("MEDIATYPE"), &ContactEditorData.HomeGeographyListMediatype,
- wxT("PREF"), &ContactEditorData.HomeGeographyListPref,
- wxT(""), &ContactEditorData.HomeGeographyListTokens );
-
- ResetSaveProcessData();
-
- }
-
- ResetSaveProcessData();
-
- for (std::map<int,wxString>::iterator iter = ContactEditorData.BusinessGeographyList.begin();
- iter != ContactEditorData.BusinessGeographyList.end(); ++iter){
-
- wxString strGeoFinalValue = iter->second;
-
- ProcessCaptureStrings(&strGeoFinalValue);
-
- if (ContactEditorData.BusinessGeographyListDataType.find(iter->first) !=
- ContactEditorData.BusinessGeographyListDataType.end()){
-
- std::map<int,wxString>::iterator DataTypeIter = ContactEditorData.BusinessGeographyListDataType.find(iter->first);
-
- strGeoFinalValue.insert(0, ":");
- strGeoFinalValue.insert(0, DataTypeIter->second);
-
- } else {
-
- strGeoFinalValue.insert(0, "geo:");
-
- }
-
- ProcessSaveData(wxT("GEO;TYPE=work"), &strValue2, &boolValue2, &boolValue,
- &iter, &strGeoFinalValue, &ContactData,
- wxT("ALTID"), &ContactEditorData.BusinessGeographyListAltID,
- wxT("PID"), &ContactEditorData.BusinessGeographyListPID,
- wxT("MEDIATYPE"), &ContactEditorData.BusinessGeographyListMediatype,
- wxT("PREF"), &ContactEditorData.BusinessGeographyListPref,
- wxT(""), &ContactEditorData.BusinessGeographyListTokens );
-
- ResetSaveProcessData();
-
- }
-
- ResetSaveProcessData();
-
- for (std::map<int,wxString>::iterator iter = ContactEditorData.GeneralRelatedList.begin();
- iter != ContactEditorData.GeneralRelatedList.end(); ++iter){
-
- ProcessSaveData(wxT("RELATED"), &strValue2, &boolValue2, &boolValue,
- &iter, &ContactEditorData.GeneralRelatedList, &ContactData,
- wxT("ALTID"), &ContactEditorData.GeneralRelatedListAltID,
- wxT("PID"), &ContactEditorData.GeneralRelatedListPID,
- wxT("LANGUAGE"), &ContactEditorData.GeneralRelatedListLanguage,
- wxT("TYPE"), &ContactEditorData.GeneralRelatedListRelType,
- wxT("PREF"), &ContactEditorData.GeneralRelatedListPref,
- wxT(""), &ContactEditorData.GeneralRelatedListTokens );
-
- ResetSaveProcessData();
-
- }
-
- ResetSaveProcessData();
-
- for (std::map<int,wxString>::iterator iter = ContactEditorData.GeneralWebsiteList.begin();
- iter != ContactEditorData.GeneralWebsiteList.end(); ++iter){
-
- ProcessSaveData(wxT("URL"), &strValue2, &boolValue2, &boolValue,
- &iter, &ContactEditorData.GeneralWebsiteList, &ContactData,
- wxT("ALTID"), &ContactEditorData.GeneralWebsiteListAltID,
- wxT("PID"), &ContactEditorData.GeneralWebsiteListPID,
- wxT("MEDIATYPE"), &ContactEditorData.GeneralWebsiteListMediatype,
- wxT("PREF"), &ContactEditorData.GeneralWebsiteListPref,
- wxT(""), &ContactEditorData.GeneralWebsiteListTokens );
-
- ResetSaveProcessData();
-
- }
-
- ResetSaveProcessData();
-
- for (std::map<int,wxString>::iterator iter = ContactEditorData.HomeWebsiteList.begin();
- iter != ContactEditorData.HomeWebsiteList.end(); ++iter){
-
- ProcessSaveData(wxT("URL;TYPE=home"), &strValue2, &boolValue2, &boolValue,
- &iter, &ContactEditorData.HomeWebsiteList, &ContactData,
- wxT("ALTID"), &ContactEditorData.HomeWebsiteListAltID,
- wxT("PID"), &ContactEditorData.HomeWebsiteListPID,
- wxT("MEDIATYPE"), &ContactEditorData.HomeWebsiteListMediatype,
- wxT("PREF"), &ContactEditorData.HomeWebsiteListPref,
- wxT(""), &ContactEditorData.HomeWebsiteListTokens );
-
- ResetSaveProcessData();
-
- }
-
- ResetSaveProcessData();
-
- for (std::map<int,wxString>::iterator iter = ContactEditorData.BusinessWebsiteList.begin();
- iter != ContactEditorData.BusinessWebsiteList.end(); ++iter){
-
- ProcessSaveData(wxT("URL;TYPE=work"), &strValue2, &boolValue2, &boolValue,
- &iter, &ContactEditorData.BusinessWebsiteList, &ContactData,
- wxT("ALTID"), &ContactEditorData.BusinessWebsiteListAltID,
- wxT("PID"), &ContactEditorData.BusinessWebsiteListPID,
- wxT("MEDIATYPE"), &ContactEditorData.BusinessWebsiteListMediatype,
- wxT("PREF"), &ContactEditorData.BusinessWebsiteListPref,
- wxT(""), &ContactEditorData.BusinessWebsiteListTokens );
-
- ResetSaveProcessData();
-
- }
-
- ResetSaveProcessData();
-
- for (std::map<int,wxString>::iterator iter = ContactEditorData.GeneralTitleList.begin();
- iter != ContactEditorData.GeneralTitleList.end(); ++iter){
-
- ProcessSaveData(wxT("TITLE"), &strValue2, &boolValue2, &boolValue,
- &iter, &ContactEditorData.GeneralTitleList, &ContactData,
- wxT("ALTID"), &ContactEditorData.GeneralTitleListAltID,
- wxT("PID"), &ContactEditorData.GeneralTitleListPID,
- wxT("LANGUAGE"), &ContactEditorData.GeneralTitleListLanguage,
- wxT("PREF"), &ContactEditorData.GeneralTitleListPref,
- wxT(""), &ContactEditorData.GeneralTitleListTokens );
-
- ResetSaveProcessData();
-
- }
-
- ResetSaveProcessData();
-
- for (std::map<int,wxString>::iterator iter = ContactEditorData.HomeTitleList.begin();
- iter != ContactEditorData.HomeTitleList.end(); ++iter){
-
- ProcessSaveData(wxT("TITLE;TYPE=home"), &strValue2, &boolValue2, &boolValue,
- &iter, &ContactEditorData.HomeTitleList, &ContactData,
- wxT("ALTID"), &ContactEditorData.HomeTitleListAltID,
- wxT("PID"), &ContactEditorData.HomeTitleListPID,
- wxT("LANGUAGE"), &ContactEditorData.HomeTitleListLanguage,
- wxT("PREF"), &ContactEditorData.HomeTitleListPref,
- wxT(""), &ContactEditorData.HomeTitleListTokens );
-
- ResetSaveProcessData();
-
- }
-
- ResetSaveProcessData();
-
- for (std::map<int,wxString>::iterator iter = ContactEditorData.BusinessTitleList.begin();
- iter != ContactEditorData.BusinessTitleList.end(); ++iter){
-
- ProcessSaveData(wxT("TITLE;TYPE=work"), &strValue2, &boolValue2, &boolValue,
- &iter, &ContactEditorData.BusinessTitleList, &ContactData,
- wxT("ALTID"), &ContactEditorData.BusinessTitleListAltID,
- wxT("PID"), &ContactEditorData.BusinessTitleListPID,
- wxT("LANGUAGE"), &ContactEditorData.BusinessTitleListLanguage,
- wxT("PREF"), &ContactEditorData.BusinessTitleListPref,
- wxT(""), &ContactEditorData.BusinessTitleListTokens );
-
- ResetSaveProcessData();
-
- }
-
- ResetSaveProcessData();
-
- for (std::map<int,wxString>::iterator iter = ContactEditorData.GeneralRoleList.begin();
- iter != ContactEditorData.GeneralRoleList.end(); ++iter){
-
- ProcessSaveData(wxT("ROLE"), &strValue2, &boolValue2, &boolValue,
- &iter, &ContactEditorData.GeneralRoleList, &ContactData,
- wxT("ALTID"), &ContactEditorData.GeneralRoleListAltID,
- wxT("PID"), &ContactEditorData.GeneralRoleListPID,
- wxT("LANGUAGE"), &ContactEditorData.GeneralRoleListLanguage,
- wxT("PREF"), &ContactEditorData.GeneralRoleListPref,
- wxT(""), &ContactEditorData.GeneralRoleListTokens );
-
- ResetSaveProcessData();
-
- }
-
- ResetSaveProcessData();
-
- for (std::map<int,wxString>::iterator iter = ContactEditorData.HomeRoleList.begin();
- iter != ContactEditorData.HomeRoleList.end(); ++iter){
-
- ProcessSaveData(wxT("ROLE;TYPE=home"), &strValue2, &boolValue2, &boolValue,
- &iter, &ContactEditorData.HomeRoleList, &ContactData,
- wxT("ALTID"), &ContactEditorData.HomeRoleListAltID,
- wxT("PID"), &ContactEditorData.HomeRoleListPID,
- wxT("LANGUAGE"), &ContactEditorData.HomeRoleListLanguage,
- wxT("PREF"), &ContactEditorData.HomeRoleListPref,
- wxT(""), &ContactEditorData.HomeRoleListTokens );
-
- ResetSaveProcessData();
-
- }
-
- ResetSaveProcessData();
-
- for (std::map<int,wxString>::iterator iter = ContactEditorData.BusinessRoleList.begin();
- iter != ContactEditorData.BusinessRoleList.end(); ++iter){
-
- ProcessSaveData(wxT("ROLE;TYPE=work"), &strValue2, &boolValue2, &boolValue,
- &iter, &ContactEditorData.BusinessRoleList, &ContactData,
- wxT("ALTID"), &ContactEditorData.BusinessRoleListAltID,
- wxT("PID"), &ContactEditorData.BusinessRoleListPID,
- wxT("LANGUAGE"), &ContactEditorData.BusinessRoleListLanguage,
- wxT("PREF"), &ContactEditorData.BusinessRoleListPref,
- wxT(""), &ContactEditorData.BusinessRoleListTokens );
-
- ResetSaveProcessData();
-
- }
-
- ResetSaveProcessData();
-
- for (std::map<int,wxString>::iterator iter = ContactEditorData.GeneralOrganisationsList.begin();
- iter != ContactEditorData.GeneralOrganisationsList.end(); ++iter){
-
- ProcessSaveData(wxT("ORG"), &strValue2, &boolValue2, &boolValue,
- &iter, &ContactEditorData.GeneralOrganisationsList, &ContactData,
- wxT("ALTID"), &ContactEditorData.GeneralOrganisationsListAltID,
- wxT("PID"), &ContactEditorData.GeneralOrganisationsListPID,
- wxT("LANGUAGE"), &ContactEditorData.GeneralOrganisationsListLanguage,
- wxT("SORT-AS"), &ContactEditorData.GeneralOrganisationsListSortAs,
- wxT("PREF"), &ContactEditorData.GeneralOrganisationsListPref,
- wxT(""), &ContactEditorData.GeneralOrganisationsListTokens );
-
- ResetSaveProcessData();
-
- }
-
- ResetSaveProcessData();
-
- for (std::map<int,wxString>::iterator iter = ContactEditorData.HomeOrganisationsList.begin();
- iter != ContactEditorData.HomeOrganisationsList.end(); ++iter){
-
- ProcessSaveData(wxT("ORG;TYPE=home"), &strValue2, &boolValue2, &boolValue,
- &iter, &ContactEditorData.HomeOrganisationsList, &ContactData,
- wxT("ALTID"), &ContactEditorData.HomeOrganisationsListAltID,
- wxT("PID"), &ContactEditorData.HomeOrganisationsListPID,
- wxT("LANGUAGE"), &ContactEditorData.HomeOrganisationsListLanguage,
- wxT("SORT-AS"), &ContactEditorData.HomeOrganisationsListSortAs,
- wxT("PREF"), &ContactEditorData.HomeOrganisationsListPref,
- wxT(""), &ContactEditorData.HomeOrganisationsListTokens );
-
- ResetSaveProcessData();
-
- }
-
- ResetSaveProcessData();
-
- for (std::map<int,wxString>::iterator iter = ContactEditorData.BusinessOrganisationsList.begin();
- iter != ContactEditorData.BusinessOrganisationsList.end(); ++iter){
-
- ProcessSaveData(wxT("ORG;TYPE=work"), &strValue2, &boolValue2, &boolValue,
- &iter, &ContactEditorData.BusinessOrganisationsList, &ContactData,
- wxT("ALTID"), &ContactEditorData.BusinessOrganisationsListAltID,
- wxT("PID"), &ContactEditorData.BusinessOrganisationsListPID,
- wxT("LANGUAGE"), &ContactEditorData.BusinessOrganisationsListLanguage,
- wxT("SORT-AS"), &ContactEditorData.BusinessOrganisationsListSortAs,
- wxT("PREF"), &ContactEditorData.BusinessOrganisationsListPref,
- wxT(""), &ContactEditorData.BusinessOrganisationsListTokens );
-
- ResetSaveProcessData();
-
- }
-
- ResetSaveProcessData();
-
- for (std::map<int,wxString>::iterator iter = ContactEditorData.GeneralNoteList.begin();
- iter != ContactEditorData.GeneralNoteList.end(); ++iter){
-
- ProcessSaveData(wxT("NOTE"), &strValue2, &boolValue2, &boolValue,
- &iter, &ContactEditorData.GeneralNoteList, &ContactData,
- wxT("ALTID"), &ContactEditorData.GeneralNoteListAltID,
- wxT("PID"), &ContactEditorData.GeneralNoteListPID,
- wxT("LANGUAGE"), &ContactEditorData.GeneralNoteListLanguage,
- wxT("PREF"), &ContactEditorData.GeneralNoteListPref,
- wxT(""), &ContactEditorData.GeneralNoteListTokens );
-
- ResetSaveProcessData();
-
- }
-
- ResetSaveProcessData();
-
- for (std::map<int,wxString>::iterator iter = ContactEditorData.HomeNoteList.begin();
- iter != ContactEditorData.HomeNoteList.end(); ++iter){
-
- ProcessSaveData(wxT("NOTE;TYPE=home"), &strValue2, &boolValue2, &boolValue,
- &iter, &ContactEditorData.HomeNoteList, &ContactData,
- wxT("ALTID"), &ContactEditorData.HomeNoteListAltID,
- wxT("PID"), &ContactEditorData.HomeNoteListPID,
- wxT("LANGUAGE"), &ContactEditorData.HomeNoteListLanguage,
- wxT("PREF"), &ContactEditorData.HomeNoteListPref,
- wxT(""), &ContactEditorData.HomeNoteListTokens );
-
- ResetSaveProcessData();
-
- }
-
- ResetSaveProcessData();
-
- for (std::map<int,wxString>::iterator iter = ContactEditorData.BusinessNoteList.begin();
- iter != ContactEditorData.BusinessNoteList.end(); ++iter){
-
- ProcessSaveData(wxT("NOTE;TYPE=work"), &strValue2, &boolValue2, &boolValue,
- &iter, &ContactEditorData.BusinessNoteList, &ContactData,
- wxT("ALTID"), &ContactEditorData.BusinessNoteListAltID,
- wxT("PID"), &ContactEditorData.BusinessNoteListPID,
- wxT("LANGUAGE"), &ContactEditorData.BusinessNoteListLanguage,
- wxT("PREF"), &ContactEditorData.BusinessNoteListPref,
- wxT(""), &ContactEditorData.BusinessNoteListTokens );
-
- ResetSaveProcessData();
-
- }
-
- ResetSaveProcessData();
-
- for (std::map<int,wxString>::iterator iter = ContactEditorData.CategoriesList.begin();
- iter != ContactEditorData.CategoriesList.end(); ++iter){
-
- ProcessSaveData(wxT("CATEGORIES"), &strValue2, &boolValue2, &boolValue,
- &iter, &ContactEditorData.CategoriesList, &ContactData,
- wxT("ALTID"), &ContactEditorData.CategoriesListAltID,
- wxT("PID"), &ContactEditorData.CategoriesListPID,
- wxT("TYPE"), &ContactEditorData.CategoriesListType,
- wxT("PREF"), &ContactEditorData.CategoriesListPref,
- wxT(""), &ContactEditorData.CategoriesListTokens );
-
- ResetSaveProcessData();
-
- }
-
- // Pictures.
-
- for (std::map<int, std::string>::iterator iter = ContactEditorData.PicturesList.begin();
- iter != ContactEditorData.PicturesList.end(); ++iter){
-
- int intValueIndex = iter->first;
-
- std::map<int, std::string>::iterator stdstriter;
- std::map<int, wxString>::iterator enciter;
-
- striter = ContactEditorData.PicturesListPictureType.find(intValueIndex);
- enciter = ContactEditorData.PicturesListPicEncType.find(intValueIndex);
-
- ProcessSaveData(wxT("PHOTO"), &strValue2, &boolValue2, &boolValue,
- &iter, &ContactEditorData.PicturesList, &striter,
- &enciter, &ContactData,
- wxT("ALTID"), &ContactEditorData.PicturesListAltID,
- wxT("PID"), &ContactEditorData.PicturesListPID,
- wxT("TYPE"), &ContactEditorData.PicturesListType,
- wxT("PREF"), &ContactEditorData.PicturesListPref,
- wxT(""), &ContactEditorData.PicturesListTokens);
-
- ResetSaveProcessData();
-
- }
-
- ResetSaveProcessData();
-
- // Logos.
-
- for (std::map<int, std::string>::iterator iter = ContactEditorData.LogosList.begin();
- iter != ContactEditorData.LogosList.end(); ++iter){
-
- int intValueIndex = iter->first;
-
- std::map<int, std::string>::iterator stdstriter;
- std::map<int, wxString>::iterator enciter;
-
- striter = ContactEditorData.LogosListPictureType.find(intValueIndex);
- enciter = ContactEditorData.LogosListPicEncType.find(intValueIndex);
-
- ProcessSaveData(wxT("LOGO"), &strValue2, &boolValue2, &boolValue,
- &iter, &ContactEditorData.LogosList, &striter,
- &enciter, &ContactData,
- wxT("ALTID"), &ContactEditorData.LogosListAltID,
- wxT("PID"), &ContactEditorData.LogosListPID,
- wxT("TYPE"), &ContactEditorData.LogosListType,
- wxT("PREF"), &ContactEditorData.LogosListPref,
- wxT(""), &ContactEditorData.LogosListTokens );
-
- ResetSaveProcessData();
-
- }
-
- ResetSaveProcessData();
-
- // Sounds.
-
- for (std::map<int, std::string>::iterator iter = ContactEditorData.SoundsList.begin();
- iter != ContactEditorData.SoundsList.end(); ++iter){
-
- int intValueIndex = iter->first;
-
- std::map<int, std::string>::iterator stdstriter;
- std::map<int, wxString>::iterator enciter;
-
- striter = ContactEditorData.SoundsListAudioType.find(intValueIndex);
- enciter = ContactEditorData.SoundsListAudioEncType.find(intValueIndex);
-
- ProcessSaveData(wxT("SOUND"), &strValue2, &boolValue2, &boolValue,
- &iter, &ContactEditorData.SoundsList, &striter,
- &enciter, &ContactData,
- wxT("ALTID"), &ContactEditorData.SoundsListAltID,
- wxT("PID"), &ContactEditorData.SoundsListPID,
- wxT("TYPE"), &ContactEditorData.SoundsListType,
- wxT("PREF"), &ContactEditorData.SoundsListPref,
- wxT(""), &ContactEditorData.SoundsListTokens );
-
- ResetSaveProcessData();
-
- }
-
- ResetSaveProcessData();
-
- for (std::map<int,wxString>::iterator iter = ContactEditorData.CalendarList.begin();
- iter != ContactEditorData.CalendarList.end(); ++iter){
-
- ProcessSaveData(wxT("CALURI"), &strValue2, &boolValue2, &boolValue,
- &iter, &ContactEditorData.CalendarList, &ContactData,
- wxT("ALTID"), &ContactEditorData.CalendarListAltID,
- wxT("PID"), &ContactEditorData.CalendarListPID,
- wxT("MEDIATYPE"), &ContactEditorData.CalendarListMediatype,
- wxT("TYPE"), &ContactEditorData.CalendarListType,
- wxT("PREF"), &ContactEditorData.CalendarListPref,
- wxT(""), &ContactEditorData.CalendarListTokens );
-
- ResetSaveProcessData();
-
- }
-
- ResetSaveProcessData();
-
- for (std::map<int,wxString>::iterator iter = ContactEditorData.CalendarRequestList.begin();
- iter != ContactEditorData.CalendarRequestList.end(); ++iter){
-
- ProcessSaveData(wxT("CALADRURI"), &strValue2, &boolValue2, &boolValue,
- &iter, &ContactEditorData.CalendarRequestList, &ContactData,
- wxT("ALTID"), &ContactEditorData.CalendarRequestListAltID,
- wxT("PID"), &ContactEditorData.CalendarRequestListPID,
- wxT("MEDIATYPE"), &ContactEditorData.CalendarRequestListMediatype,
- wxT("TYPE"), &ContactEditorData.CalendarRequestListType,
- wxT("PREF"), &ContactEditorData.CalendarRequestListPref,
- wxT(""), &ContactEditorData.CalendarRequestListTokens );
-
- ResetSaveProcessData();
-
- }
-
- ResetSaveProcessData();
-
- for (std::map<int,wxString>::iterator iter = ContactEditorData.FreeBusyList.begin();
- iter != ContactEditorData.FreeBusyList.end(); ++iter){
-
- ProcessSaveData(wxT("FBURL"), &strValue2, &boolValue2, &boolValue,
- &iter, &ContactEditorData.FreeBusyList, &ContactData,
- wxT("ALTID"), &ContactEditorData.FreeBusyListAltID,
- wxT("PID"), &ContactEditorData.FreeBusyListPID,
- wxT("MEDIATYPE"), &ContactEditorData.FreeBusyListMediatype,
- wxT("TYPE"), &ContactEditorData.FreeBusyListType,
- wxT("PREF"), &ContactEditorData.FreeBusyListPref,
- wxT(""), &ContactEditorData.FreeBusyListTokens );
-
- ResetSaveProcessData();
-
- }
-
- for (std::map<int, wxString>::iterator iter = ContactEditorData.KeyList.begin();
- iter != ContactEditorData.KeyList.end(); ++iter){
-
- intValue2 = iter->first;
-
- // Get the key information.
-
- std::map<int, wxString>::iterator enciter;
-
- striter = ContactEditorData.KeyListDataType.find(intValue2);
-
- wxString strValueData;
-
- strValueData = iter->second;
- strValueData.insert(0, wxT("data:") + striter->second + wxT(";base64,"));
-
- ProcessSaveData(wxT("KEY"), &strValue2, &boolValue2, &boolValue,
- &iter, &strValueData, &ContactData,
- wxT("ALTID"), &ContactEditorData.KeyListAltID,
- wxT("PID"), &ContactEditorData.KeyListPID,
- wxT("TYPE"), &ContactEditorData.KeyListType,
- wxT("PREF"), &ContactEditorData.KeyListPref,
- wxT(""), &ContactEditorData.KeyListTokens );
-
- ResetSaveProcessData();
-
- }
-
- // Vendor specific items.
-
- ResetSaveProcessData();
-
- for (std::map<int,wxString>::iterator iter = ContactEditorData.VendorList.begin();
- iter != ContactEditorData.VendorList.end(); ++iter){
-
- intValue2 = iter->first;
-
- // Get the IANA PEN number.
-
- striter = ContactEditorData.VendorListPEN.find(intValue2);
-
- if (striter->first == intValue2){
-
- strValue2 = striter->second;
-
- }
-
- // Get the element name.
-
- striter = ContactEditorData.VendorListElement.find(intValue2);
-
- if (striter->first == intValue2){
-
- strValue3 = striter->second;
-
- }
-
- // Get the address.
-
- striter = ContactEditorData.VendorList.find(intValue2);
-
- if (striter->first == intValue2){
-
- strValue = striter->second;
-
- }
-
- // Add to the vCard.
-
- if (boolValue == TRUE){
-
- ContactData.AddRaw(wxT("VND-") + strValue2 + wxT("-") + strValue3, strValue);
-
- } else {
-
- ContactData.Add(wxT("VND-") + strValue2 + wxT("-") + strValue3, strValue, FALSE);
-
- }
-
- ResetSaveProcessData();
-
- }
-
- ResetSaveProcessData();
-
- // X-Tokens.
-
- for (std::map<int,wxString>::iterator iter = ContactEditorData.XTokenList.begin();
- iter != ContactEditorData.XTokenList.end(); ++iter){
-
- intValue2 = iter->first;
-
- // Get the element name.
-
- striter = ContactEditorData.XTokenListTokens.find(intValue2);
-
- if (striter->first == intValue2){
-
- strValue2 = striter->second;
-
- }
-
- // Get the address.
-
- striter = ContactEditorData.XTokenList.find(intValue2);
-
- if (striter->first == intValue2){
-
- strValue = striter->second;
-
- }
-
- // Add to the vCard.
-
- if (boolValue == TRUE){
-
- ContactData.AddRaw(wxT("X-") + strValue2, strValue);
-
- } else {
-
- ContactData.Add(wxT("X-") + strValue2, strValue, FALSE);
-
- }
-
- ResetSaveProcessData();
-
- }
-
- ResetSaveProcessData();
-
- if (ContactEditorData.FullNamesList.size() == 0){
-
- wxString FullName = cmbDisplayAs->GetValue();
- ContactEditorData.FullNamesList.insert(std::make_pair(0, FullName));
- ContactEditorData.FullNamesListAltID.insert(std::make_pair(0, wxT("")));
- ContactEditorData.FullNamesListPID.insert(std::make_pair(0, wxT("")));
- ContactEditorData.FullNamesListType.insert(std::make_pair(0, wxT("")));
- ContactEditorData.FullNamesListLanguage.insert(std::make_pair(0, wxT("")));
- ContactEditorData.FullNamesListPref.insert(std::make_pair(0, 0));
- ContactEditorData.FullNamesListTokens.insert(std::make_pair(0, wxT("")));
- FNFirst = FALSE;
-
- }
-
- for (std::map<int, wxString>::iterator iter = ContactEditorData.FullNamesList.begin();
- iter != ContactEditorData.FullNamesList.end(); ++iter){
-
- if (FNFirst == TRUE){
-
- iter->second = cmbDisplayAs->GetValue();
- FNFirst = FALSE;
-
- }
-
- std::map<int,wxString>::iterator mapS;
-
- mapS = ContactEditorData.FullNamesListTokens.find(iter->first);
-
- ProcessSaveData(wxT("FN"), &strValue2, &boolValue2, &boolValue,
- &iter, &ContactEditorData.FullNamesList, &ContactData,
- wxT("ALTID"), &ContactEditorData.FullNamesListAltID,
- wxT("PID"), &ContactEditorData.FullNamesListPID,
- wxT("TYPE"), &ContactEditorData.FullNamesListType,
- wxT("LANGUAGE"), &ContactEditorData.FullNamesListLanguage,
- wxT("PREF"), &ContactEditorData.FullNamesListPref,
- wxT(""), &ContactEditorData.FullNamesListTokens );
-
- // Get the address.
-
- ResetSaveProcessData();
-
- }
-
- // Insert revision (REV) date.
-
- // Get today's date and time.
-
- wxDateTime DateTimeNow = wxDateTime::Now();
-
- wxString DateRev;
-
- // Set year, month and date.
-
- int intYear = DateTimeNow.GetYear();
- int intMonth = DateTimeNow.GetMonth();
- int intDay = DateTimeNow.GetDay();
-
- DateRev.Append(wxT("0") + wxString::Format(wxT("%i"), intYear));
-
- if (intMonth < 10){
-
- DateRev.Append(wxT("0") + wxString::Format(wxT("%i"), intMonth));
-
- } else {
-
- DateRev.Append(wxString::Format(wxT("%i"), intMonth));
-
- }
-
- if (intDay < 10){
-
- DateRev.Append(wxT("0") + wxString::Format(wxT("%i"), intDay));
-
- } else {
-
- DateRev.Append(wxString::Format(wxT("%i"), intDay));
-
- }
-
- DateRev.Append(wxT("T"));
-
- // Set hour, minute and second.
-
- int intHour = DateTimeNow.GetHour();
- int intMinute = DateTimeNow.GetMinute();
- int intSecond = DateTimeNow.GetSecond();
-
- if (intHour < 10){
-
- DateRev.Append(wxT("0") + wxString::Format(wxT("%i"), intHour));
-
- } else {
-
- DateRev.Append(wxString::Format(wxT("%i"), intHour));
-
- }
-
- if (intMinute < 10){
-
- DateRev.Append(wxT("0") + wxString::Format(wxT("%i"), intMinute));
-
- } else {
-
- DateRev.Append(wxString::Format(wxT("%i"), intMinute));
-
- }
-
- if (intSecond < 10){
-
- DateRev.Append(wxT("0") + wxString::Format(wxT("%i"), intSecond));
-
- } else {
-
- DateRev.Append(wxString::Format(wxT("%i"), intSecond));
-
- }
-
- DateRev.Append(wxT("Z"));
-
- ContactData.Add(wxT("UID"), ContactEditorData.UIDToken, FALSE);
-
- // End the vCard File.
-
- ContactData.Add(wxT("END"), wxT("VCARD"), FALSE);*/
FMTimer.Stop();
ContactEditorData.SaveFile(FilenameFinal);
- //ContactData.WriteFile(FilenameFinal);
vCard34Conv ConvFileFun;