&ContactEditorData.BusinessAddressListPref,
&ADRCount);
- // Process the timezones (TZ) (frmContactEditor-LoadTimeZone.cpp)
+ // Process the timezones (TZ).
LoadData(&ContactEditorData.GeneralTZList,
&ContactEditorData.GeneralTZListPref,
lboBusinessTimezones,
&TZCount);
- // Process the emails (EMAIL) (frmContactEditor-LoadEmail.cpp)
+ // Process the emails (EMAIL).
LoadData(&ContactEditorData.GeneralEmailList,
&ContactEditorData.GeneralEmailListPref,
lboBusinessEmail,
&EmailCount);
- // Process the nicknames (NICKNAME) (frmContactEditor-LoadNickname.cpp)
+ // Process the nicknames (NICKNAME).
LoadData(&ContactEditorData.GeneralNicknamesList,
&ContactEditorData.GeneralNicknamesListPref,
&ContactEditorData.BusinessNicknamesListPref,
lboBusinessNicknames,
&NicknameCount);
+
+ // Process the languages (LANG).
+
+ LoadData(&ContactEditorData.GeneralLanguageList,
+ &ContactEditorData.GeneralLanguageListPref,
+ lboLanguages,
+ &ContactEditorData.HomeLanguageList,
+ &ContactEditorData.HomeLanguageListPref,
+ lboHomeLanguages,
+ &ContactEditorData.BusinessLanguageList,
+ &ContactEditorData.BusinessLanguageListPref,
+ lboBusinessLanguages,
+ &LangCount);
+
+ // Process the geopositiosn (GEO).
+
+ LoadData(&ContactEditorData.GeneralGeographyList,
+ &ContactEditorData.GeneralGeographyListPref,
+ lboGeoposition,
+ &ContactEditorData.HomeGeographyList,
+ &ContactEditorData.HomeGeographyListPref,
+ lboHomeGeoposition,
+ &ContactEditorData.BusinessGeographyList,
+ &ContactEditorData.BusinessGeographyListPref,
+ lboBusinessGeoposition,
+ &GeoCount);
+
+ // Process the websites (URL).
+
+ LoadData(&ContactEditorData.GeneralWebsiteList,
+ &ContactEditorData.GeneralWebsiteListPref,
+ lboWebsites,
+ &ContactEditorData.HomeWebsiteList,
+ &ContactEditorData.HomeWebsiteListPref,
+ lboHomeWebsites,
+ &ContactEditorData.BusinessWebsiteList,
+ &ContactEditorData.BusinessWebsiteListPref,
+ lboBusinessWebsites,
+ &URLCount);
+
+ // Process the titles (TITLE).
+
+ LoadData(&ContactEditorData.GeneralTitleList,
+ &ContactEditorData.GeneralTitleListPref,
+ lboTitles,
+ &ContactEditorData.HomeTitleList,
+ &ContactEditorData.HomeTitleListPref,
+ lboHomeTitles,
+ &ContactEditorData.BusinessTitleList,
+ &ContactEditorData.BusinessTitleListPref,
+ lboBusinessTitles,
+ &TitleCount);
+
+ // Process the roles (ROLE).
+
+ LoadData(&ContactEditorData.GeneralRoleList,
+ &ContactEditorData.GeneralRoleListPref,
+ lboRoles,
+ &ContactEditorData.HomeRoleList,
+ &ContactEditorData.HomeRoleListPref,
+ lboHomeRoles,
+ &ContactEditorData.BusinessRoleList,
+ &ContactEditorData.BusinessRoleListPref,
+ lboBusinessRoles,
+ &RoleCount);
+
+ // Process the roles (ORG).
+
+ LoadData(&ContactEditorData.GeneralOrganisationsList,
+ &ContactEditorData.GeneralOrganisationsListPref,
+ lboOrganisations,
+ &ContactEditorData.HomeOrganisationsList,
+ &ContactEditorData.HomeOrganisationsListPref,
+ lboHomeOrganisations,
+ &ContactEditorData.BusinessOrganisationsList,
+ &ContactEditorData.BusinessOrganisationsListPref,
+ lboBusinessOrganisations,
+ &OrgCount);
+
+ // Process the notes (NOTE).
+
+ LoadData(&ContactEditorData.GeneralNoteList,
+ &ContactEditorData.GeneralNoteListPref,
+ lboNotes,
+ &ContactEditorData.HomeNoteList,
+ &ContactEditorData.HomeNoteListPref,
+ lboHomeNotes,
+ &ContactEditorData.BusinessNoteList,
+ &ContactEditorData.BusinessNoteListPref,
+ lboBusinessNotes,
+ &NoteCount);
+
+ // Process the categories (CATEGORIES).
+
+ LoadData(&ContactEditorData.CategoriesList,
+ &ContactEditorData.CategoriesListPref,
+ lboCategories,
+ &CategoryCount);
for (std::map<int,wxString>::iterator iter = ContactFileLines.begin();
iter != ContactFileLines.end(); ++iter){
LoadTelephone(wxSPropertySeg1, wxSPropertySeg2, &TelCount);
- } else if (wxSProperty == wxT("LANG")){
+ }/* else if (wxSProperty == wxT("LANG")){
// See frmContactEditor-LoadLanguage.cpp
LoadGeo(wxSPropertySeg1, wxSPropertySeg2, &GeoCount);
- } else if (wxSProperty == wxT("RELATED")){
+ }*/ else if (wxSProperty == wxT("RELATED")){
// See fromContactEditor-LoadRelated.cpp
LoadRelated(wxSPropertySeg1, wxSPropertySeg2, &RelatedCount);
- } else if (wxSProperty == wxT("URL")){
+ }/* else if (wxSProperty == wxT("URL")){
// See frmContactEditor-LoadURL.cpp
LoadCategory(wxSPropertySeg1, wxSPropertySeg2, &CategoryCount);
- } else if (wxSProperty == wxT("PHOTO")) {
+ }*/ else if (wxSProperty == wxT("PHOTO")) {
// See frmContactEditor-LoadPhoto.cpp
long ListCtrlIndex = -1;
- // Deal with the general addresses.
+ // Deal with the general items.
for (std::map<int,wxString>::iterator Iter = GeneralList->begin();
Iter != GeneralList->end();
}
- // Deal with the home addresses.
+ // Deal with the home items.
for (std::map<int,wxString>::iterator Iter = HomeList->begin();
Iter != HomeList->end();
}
- // Deal with the work addresses.
+ // Deal with the work items.
for (std::map<int,wxString>::iterator Iter = BusinessList->begin();
Iter != BusinessList->end();
}
+}
+
+void frmContactEditor::LoadData(std::map<int,wxString> *ItemList,
+ std::map<int,int> *ItemListPref,
+ wxListCtrl *ItemCtrl,
+ int *DataCount){
+
+ long ListCtrlIndex = -1;
+
+ for (std::map<int,wxString>::iterator Iter = ItemList->begin();
+ Iter != ItemList->end();
+ Iter++){
+
+ wxListItem coldata;
+
+ coldata.SetId(*DataCount);
+ coldata.SetData(*DataCount);
+ coldata.SetText(Iter->second);
+
+ ListCtrlIndex = ItemCtrl->InsertItem(coldata);
+
+ if (MapDataExists(DataCount, ItemListPref)){
+
+ ItemCtrl->SetItem(ListCtrlIndex, 1, wxString::Format("%i", ItemListPref->find(*DataCount)->second));
+
+ }
+
+ (*DataCount)++;
+
+ }
+
}
\ No newline at end of file