char buf[256];
long len;
char *Name;
+ const char *VCName;
void *Namee;
+ StrBuf *DefAddrBook;
HashList *List;
HashPos *it;
begin_ajax_response();
+ DefAddrBook = get_room_pref("defaddrbook");
+
wprintf("<table border=0 width=100%%><tr valign=middle>");
wprintf("<td align=left><img src=\"static/viewcontacts_32x.gif\"></td>");
wprintf("<td align=center>");
bstr("target_input")
);
- wprintf("<option value=\"__LOCAL_USERS__\">");
+ wprintf("<option value=\"__LOCAL_USERS__\" %s>",
+ (strcmp(ChrPtr(DefAddrBook), "__LOCAL_USERS__") == 0)?
+ "selected=\"selected\" ":"");
escputs(serv_info.serv_humannode);
wprintf("</option>\n");
- List = NewHash();
+ List = NewHash(1, NULL);
serv_puts("LKRA");
serv_getln(buf, sizeof buf);
if (buf[0] == '1') while(len = serv_getln(buf, sizeof buf), strcmp(buf, "000")) {
}
}
- SortByHashKey(List);
- it = GetNewHashPos();
- while (GetNextHashPos(List, it, &len, &Name, &Namee)) {
+ SortByHashKey(List, 1);
+ it = GetNewHashPos(List, 0);
+ while (GetNextHashPos(List, it, &len, &VCName, &Namee)) {
wprintf("<option value=\"");
urlescputs((char*)Namee);
- wprintf("\">");
+ if (strcmp(ChrPtr(DefAddrBook), Namee) == 0)
+ wprintf("\" selected=\"selected\" >");
+ else
+ wprintf("\">");
escputs((char*)Namee);
wprintf("</option>\n");
}
"><img src=\"static/closewindow.gif\">");
wprintf("</td></tr></table>");
- wprintf("<script type=\"text/javascript\">"
- "PopulateAddressBookInnerDiv($('which_addr_book').value,'%s');"
- "</script>\n",
+ StrBufAppendPrintf(WC->trailing_javascript,
+ "PopulateAddressBookInnerDiv($('which_addr_book').value,'%s');",
bstr("target_input")
);
char target_label[64];
long len;
char *Name;
+ const char *VCName;
void *Namee;
HashList *List;
HashPos *it;
begin_ajax_response();
- List = NewHash();
+ List = NewHash(1, NULL);
wprintf("<div align=center><form onSubmit=\"return false;\">"
"<select multiple name=\"whichaddr\" id=\"whichaddr\" size=\"15\">\n");
if (buf[0] == '1') while(len = serv_getln(buf, sizeof buf), strcmp(buf, "000")) {
Name = (char*) malloc(len + 1);
len = extract_token(Name, buf, 0, '|', len + 1);
+ if((len > 5) && (strncmp(Name, "SYS_", 4) == 0)) {
+ free(Name);
+ continue;
+ }
Put(List, Name, len, Name, NULL);
}
- SortByHashKey(List);
- it = GetNewHashPos();
- while (GetNextHashPos(List, it, &len, &Name, &Namee)) {
+ SortByHashKey(List, 1);
+ it = GetNewHashPos(List, 0);
+ while (GetNextHashPos(List, it, &len, &VCName, &Namee)) {
wprintf("<option value=\"");
escputs((char*)Namee);
wprintf("\">");
}
else {
+ set_room_pref("defaddrbook",NewStrBufDup(sbstr("which_addr_book")), 0);
safestrncpy(saved_roomname, WC->wc_roomname, sizeof saved_roomname);
gotoroom(bstr("which_addr_book"));
serv_puts("DVCA");
Put(List, Name, len, Name, NULL);
}
- SortByHashKey(List);
- it = GetNewHashPos();
- while (GetNextHashPos(List, it, &len, &Name, (void**)&Namee)) {
+ SortByHashKey(List, 1);
+ it = GetNewHashPos(List, 0);
+ while (GetNextHashPos(List, it, &len, &VCName, (void**)&Namee)) {
wprintf("<option value=\"");
escputs((char*)Namee);
wprintf("\">");
}
DeleteHashPos(&it);
DeleteHash(&List);
- gotoroom((char*)BSTR(saved_roomname)); /* TODO: get rid of typecast */
+ gotoroom(saved_roomname);
}
wprintf("</select>\n");
end_ajax_response();
}
+
+
+
+
+void
+InitModule_ADDRBOOK_POPUP
+(void)
+{
+ WebcitAddUrlHandler(HKEY("display_address_book_middle_div"), display_address_book_middle_div, 0);
+ WebcitAddUrlHandler(HKEY("display_address_book_inner_div"), display_address_book_inner_div, 0);
+}