&CalendarListAltID, &CalendarListPID,
&CalendarListType, &CalendarListPref,
&CalendarListTokens, SaveData);
+
+ // Process CALADRURI.
+
+ SaveCalendarRequestURI(&CalendarRequestList, &CalendarRequestListMediatype,
+ &CalendarRequestListAltID, &CalendarRequestListPID,
+ &CalendarRequestListType, &CalendarRequestListPref,
+ &CalendarRequestListTokens, SaveData);
+
+ // Process FBURL.
+
+ SaveFreeBusyURI(&FreeBusyList, &FreeBusyListAltID,
+ &FreeBusyListPID, &FreeBusyListType,
+ &FreeBusyListMediatype, &FreeBusyListPref,
+ &FreeBusyListTokens, SaveData);
+
+ // Process KEY.
+
+ SaveKey(&KeyList, &KeyListAltID,
+ &KeyListPID, &KeyListType,
+ &KeyListKeyType, &KeyListDataEncType,
+ &KeyListDataType, &KeyListPref,
+ &KeyListTokens, SaveData);
// Write the end part of the vCard data file.
}
+}
+
+void ContactDataObject::SaveCalendarRequestURI(map<int, wxString> *CalendarRequestList, map<int, wxString> *CalendarRequestListMediatype,
+ map<int, wxString> *CalendarRequestListAltID, map<int, wxString> *CalendarRequestListPID,
+ map<int, wxString> *CalendarRequestListType, map<int, int> *CalendarRequestListPref,
+ map<int, wxString> *CalendarRequestListTokens, wxString *SaveData){
+
+ wxString ProcessData = "";
+
+ for (std::map<int, wxString>::iterator CalendarRequestIter = CalendarRequestList->begin();
+ CalendarRequestIter != CalendarRequestList->end(); CalendarRequestIter++){
+
+ ProcessData.Append("CALADRURI");
+
+ // Check if there is a value for TYPE.
+
+ if ((*CalendarRequestListType)[CalendarRequestIter->first].size() > 0){
+
+ ProcessData.Append(";TYPE=");
+ ProcessData.Append((*CalendarRequestListType)[CalendarRequestIter->first]);
+
+ }
+
+ // Check if there is a value for ALTID.
+
+ if ((*CalendarRequestListAltID)[CalendarRequestIter->first].size() > 0){
+
+ ProcessData.Append(";ALTID=");
+ ProcessData.Append((*CalendarRequestListAltID)[CalendarRequestIter->first]);
+
+ }
+
+ // Check if there is a value for MEDIATYPE.
+
+ if ((*CalendarRequestListMediatype)[CalendarRequestIter->first].size() > 0){
+
+ ProcessData.Append(";MEDIATYPE=");
+ ProcessData.Append((*CalendarRequestListMediatype)[CalendarRequestIter->first]);
+
+ }
+
+ // Check if there is a value for PID.
+
+ if ((*CalendarRequestListPID)[CalendarRequestIter->first].size() > 0){
+
+ ProcessData.Append(";PID=");
+ ProcessData.Append((*CalendarRequestListPID)[CalendarRequestIter->first]);
+
+ }
+
+ // Check if there is a value for PREF.
+
+ if ((*CalendarRequestListPref)[CalendarRequestIter->first] > 0){
+
+ ProcessData.Append(";PREF=");
+ ProcessData.Append(wxString::Format("%i", (*CalendarRequestListPref)[CalendarRequestIter->first]));
+
+ }
+
+ // Check if there is a value for tokens.
+
+ if ((*CalendarRequestListTokens)[CalendarRequestIter->first].size() > 0){
+
+ ProcessData.Append(";");
+ ProcessData.Append((*CalendarRequestListTokens)[CalendarRequestIter->first]);
+
+ }
+
+ ProcessData.Append(":");
+ ProcessData.Append(CalendarRequestIter->second);
+ ProcessData.Append("\n");
+
+ ProcessData = OutputText(&ProcessData);
+
+ SaveData->Append(ProcessData);
+ ProcessData.clear();
+
+ }
+
+}
+
+void ContactDataObject::SaveFreeBusyURI(std::map<int, wxString> *FreeBusyList, std::map<int, wxString> *FreeBusyListAltID,
+ std::map<int, wxString> *FreeBusyListPID, std::map<int, wxString> *FreeBusyListType,
+ std::map<int, wxString> *FreeBusyListMediatype, std::map<int, int> *FreeBusyListPref,
+ std::map<int, wxString> *FreeBusyListTokens, wxString *SaveData){
+
+ wxString ProcessData = "";
+
+ for (std::map<int, wxString>::iterator FreeBusyIter = FreeBusyList->begin();
+ FreeBusyIter != FreeBusyList->end(); FreeBusyIter++){
+
+ ProcessData.Append("FBURL");
+
+ // Check if there is a value for TYPE.
+
+ if ((*FreeBusyListType)[FreeBusyIter->first].size() > 0){
+
+ ProcessData.Append(";TYPE=");
+ ProcessData.Append((*FreeBusyListType)[FreeBusyIter->first]);
+
+ }
+
+ // Check if there is a value for ALTID.
+
+ if ((*FreeBusyListAltID)[FreeBusyIter->first].size() > 0){
+
+ ProcessData.Append(";ALTID=");
+ ProcessData.Append((*FreeBusyListAltID)[FreeBusyIter->first]);
+
+ }
+
+ // Check if there is a value for MEDIATYPE.
+
+ if ((*FreeBusyListMediatype)[FreeBusyIter->first].size() > 0){
+
+ ProcessData.Append(";MEDIATYPE=");
+ ProcessData.Append((*FreeBusyListMediatype)[FreeBusyIter->first]);
+
+ }
+
+ // Check if there is a value for PID.
+
+ if ((*FreeBusyListPID)[FreeBusyIter->first].size() > 0){
+
+ ProcessData.Append(";PID=");
+ ProcessData.Append((*FreeBusyListPID)[FreeBusyIter->first]);
+
+ }
+
+ // Check if there is a value for PREF.
+
+ if ((*FreeBusyListPref)[FreeBusyIter->first] > 0){
+
+ ProcessData.Append(";PREF=");
+ ProcessData.Append(wxString::Format("%i", (*FreeBusyListPref)[FreeBusyIter->first]));
+
+ }
+
+ // Check if there is a value for tokens.
+
+ if ((*FreeBusyListTokens)[FreeBusyIter->first].size() > 0){
+
+ ProcessData.Append(";");
+ ProcessData.Append((*FreeBusyListTokens)[FreeBusyIter->first]);
+
+ }
+
+ ProcessData.Append(":");
+ ProcessData.Append(FreeBusyIter->second);
+ ProcessData.Append("\n");
+
+ ProcessData = OutputText(&ProcessData);
+
+ SaveData->Append(ProcessData);
+ ProcessData.clear();
+
+ }
+
+}
+
+void ContactDataObject::SaveKey(map<int, wxString> *KeyList, map<int, wxString> *KeyListAltID,
+ map<int, wxString> *KeyListPID, map<int, wxString> *KeyListType,
+ map<int, bool> *KeyListKeyType, map<int, wxString> *KeyListDataEncType,
+ map<int, wxString> *KeyListDataType, map<int, int> *KeyListPref,
+ map<int, wxString> *KeyListTokens, wxString *SaveData){
+
+ wxString ProcessData = "";
+
+ for (std::map<int, wxString>::iterator KeyIter = KeyList->begin();
+ KeyIter != KeyList->end(); KeyIter++){
+
+ ProcessData.Append("KEY");
+
+ // Check if there is a value for TYPE.
+
+ if ((*KeyListType)[KeyIter->first].size() > 0){
+
+ ProcessData.Append(";TYPE=");
+ ProcessData.Append((*KeyListType)[KeyIter->first]);
+
+ }
+
+ // Check if there is a value for ALTID.
+
+ if ((*KeyListAltID)[KeyIter->first].size() > 0){
+
+ ProcessData.Append(";ALTID=");
+ ProcessData.Append((*KeyListAltID)[KeyIter->first]);
+
+ }
+
+ // Check if there is a value for PID.
+
+ if ((*KeyListPID)[KeyIter->first].size() > 0){
+
+ ProcessData.Append(";PID=");
+ ProcessData.Append((*KeyListPID)[KeyIter->first]);
+
+ }
+
+ // Check if there is a value for PREF.
+
+ if ((*KeyListPref)[KeyIter->first] > 0){
+
+ ProcessData.Append(";PREF=");
+ ProcessData.Append(wxString::Format("%i", (*KeyListPref)[KeyIter->first]));
+
+ }
+
+ // Check if there is a value for tokens.
+
+ if ((*KeyListTokens)[KeyIter->first].size() > 0){
+
+ ProcessData.Append(";");
+ ProcessData.Append((*KeyListTokens)[KeyIter->first]);
+
+ }
+
+ ProcessData.Append(":data:");
+ ProcessData.Append((*KeyListDataType)[KeyIter->first]);
+ ProcessData.Append(";");
+ ProcessData.Append((*KeyListDataEncType)[KeyIter->first]);
+ ProcessData.Append(",");
+ ProcessData.Append(KeyIter->second);
+ ProcessData.Append("\n");
+
+ ProcessData = OutputText(&ProcessData);
+
+ SaveData->Append(ProcessData);
+ ProcessData.clear();
+
+ }
+
}
\ No newline at end of file