1 /* JavaScript for SOGoContacts */
3 var cachedContacts = new Array();
4 var currentContactFolder = null;
6 var usersRightsWindowHeight = 200;
7 var usersRightsWindowWidth = 450;
9 function validateEditorInput(sender) {
13 field = document.pageform.subject;
14 if (field.value == "")
15 errortext = errortext + labels.error_missingsubject + "\n";
17 if (!UIxRecipientSelectorHasRecipients())
18 errortext = errortext + labels.error_missingrecipients + "\n";
20 if (errortext.length > 0) {
21 alert(labels.error_validationfailed + ":\n"
28 function openContactsFolder(contactsFolder, reload, idx) {
29 if ((contactsFolder && contactsFolder != currentContactFolder)
31 currentContactFolder = contactsFolder;
32 var url = URLForFolderID(currentContactFolder) +
35 var searchValue = search["value"];
36 if (searchValue && searchValue.length > 0)
37 url += ("&search=" + search["criteria"]
38 + "&value=" + escape(searchValue.utf8encode()));
39 var sortAttribute = sorting["attribute"];
40 if (sortAttribute && sortAttribute.length > 0)
41 url += ("&sort=" + sorting["attribute"]
42 + "&asc=" + sorting["ascending"]);
45 if (contactsFolder == currentContactFolder) {
46 var contactsList = $("contactsList");
48 selection = contactsList.getSelectedRowsId();
50 window.alert("no contactsList");
55 if (document.contactsListAjaxRequest) {
56 document.contactsListAjaxRequest.aborted = true;
57 document.contactsListAjaxRequest.abort();
59 document.contactsListAjaxRequest
60 = triggerAjaxRequest(url, contactsListCallback, selection);
64 function openContactsFolderAtIndex(element) {
65 var idx = element.getAttribute("idx");
66 var url = URLForFolderID(currentContactFolder) + "/view?noframe=1&idx=" + idx;
68 if (document.contactsListAjaxRequest) {
69 document.contactsListAjaxRequest.aborted = true;
70 document.contactsListAjaxRequest.abort();
72 document.contactsListAjaxRequest
73 = triggerAjaxRequest(url, contactsListCallback);
76 function configureContactsListHeaders(cells) {
77 for (var i = 0; i < cells.length; i++) {
78 var currentCell = $(cells[i]);
79 Event.observe(currentCell, "click",
80 onHeaderClick.bindAsEventListener(currentCell));
81 Event.observe(currentCell, "mousedown", listRowMouseDownHandler);
85 function contactsListCallback(http) {
86 var div = $("contactsListContent");
88 if (http.readyState == 4
89 && http.status == 200) {
90 document.contactsListAjaxRequest = null;
91 div.innerHTML = http.responseText;
93 var table = $("contactsList");
95 configureContactsListHeaders(table.tBodies[0].rows[0].cells);
97 if (sorting["attribute"] && sorting["attribute"].length > 0) {
99 if (sorting["attribute"] == "displayName")
100 sortHeader = $("nameHeader");
101 else if (sorting["attribute"] == "mail")
102 sortHeader = $("mailHeader");
103 else if (sorting["attribute"] == "screenName")
104 sortHeader = $("screenNameHeader");
105 else if (sorting["attribute"] == "org")
106 sortHeader = $("orgHeader");
107 else if (sorting["attribute"] == "phone")
108 sortHeader = $("phoneHeader");
113 var sortImage = createElement("img", "messageSortImage", "sortImage");
114 sortHeader.insertBefore(sortImage, sortHeader.firstChild);
115 if (sorting["ascending"])
116 sortImage.src = ResourcesURL + "/title_sortdown_12x12.png";
118 sortImage.src = ResourcesURL + "/title_sortup_12x12.png";
122 var selected = http.callbackData;
124 for (var i = 0; i < selected.length; i++) {
125 var row = $(selected[i]);
132 log ("ajax problem 1: status = " + http.status);
135 function onContactFoldersContextMenu(event) {
136 var menu = $("contactFoldersMenu");
137 //Event.observe(menu, "hideMenu", onContactFoldersContextMenuHide, false);
138 Event.observe(menu, "mousedown", onContactFoldersContextMenuHide, false);
139 popupMenu(event, "contactFoldersMenu", this);
141 var topNode = $("contactFolders");
142 var selectedNodes = topNode.getSelectedRows();
143 topNode.menuSelectedRows = selectedNodes;
144 for (var i = 0; i < selectedNodes.length; i++)
145 $(selectedNodes[i]).deselect();
146 topNode.menuSelectedEntry = this;
150 function onContactContextMenu(event, element) {
151 var menu = $("contactMenu");
152 //Event.observe(menu, "hideMenu", onContactContextMenuHide, false);
153 Event.observe(menu, "mousedown", onContactContextMenuHide, false);
154 //document.documentElement.onclick = onContactContextMenuHide;
155 popupMenu(event, "contactMenu", element);
157 var topNode = $("contactsList");
158 var selectedNodes = topNode.getSelectedRows();
159 topNode.menuSelectedRows = selectedNodes;
160 for (var i = 0; i < selectedNodes.length; i++)
161 $(selectedNodes[i]).deselect();
162 topNode.menuSelectedEntry = element;
166 function onContactContextMenuHide(event) {
167 var topNode = $("contactsList");
169 if (topNode.menuSelectedEntry) {
170 $(topNode.menuSelectedEntry).deselect();
171 topNode.menuSelectedEntry = null;
173 if (topNode.menuSelectedRows) {
174 var nodes = topNode.menuSelectedRows;
175 for (var i = 0; i < nodes.length; i++)
176 $(nodes[i]).select();
177 topNode.menuSelectedRows = null;
181 function onContactFoldersContextMenuHide(event) {
182 var topNode = $("contactFolders");
184 if (topNode.menuSelectedEntry) {
185 topNode.menuSelectedEntry.deselect();
186 topNode.menuSelectedEntry = null;
188 if (topNode.menuSelectedRows) {
189 var nodes = topNode.menuSelectedRows;
190 for (var i = 0; i < nodes.length; i++)
192 topNode.menuSelectedRows = null;
196 function onFolderMenuHide(event) {
197 var topNode = $('d');
199 if (topNode.menuSelectedEntry) {
200 topNode.menuSelectedEntry.deselect();
201 topNode.menuSelectedEntry = null;
203 if (topNode.selectedEntry)
204 topNode.selectedEntry.select();
207 function loadContact(idx) {
208 if (document.contactAjaxRequest) {
209 document.contactAjaxRequest.aborted = true;
210 document.contactAjaxRequest.abort();
213 if (cachedContacts[currentContactFolder + "/" + idx]) {
214 var div = $('contactView');
215 div.innerHTML = cachedContacts[currentContactFolder + "/" + idx];
218 var url = (URLForFolderID(currentContactFolder)
219 + "/" + idx + "/view?noframe=1");
220 document.contactAjaxRequest
221 = triggerAjaxRequest(url, contactLoadCallback, idx);
225 function contactLoadCallback(http) {
226 var div = $('contactView');
228 if (http.readyState == 4
229 && http.status == 200) {
230 document.contactAjaxRequest = null;
231 var content = http.responseText;
232 cachedContacts[currentContactFolder + "/" + http.callbackData] = content;
233 div.innerHTML = content;
236 log ("ajax problem 2: " + http.status);
239 var rowSelectionCount = 0;
243 function showElement(e, shouldShow) {
244 e.style.display = shouldShow ? "" : "none";
247 function enableElement(e, shouldEnable) {
251 if(e.hasAttribute("disabled"))
252 e.removeAttribute("disabled");
255 e.setAttribute("disabled", "1");
259 function validateControls() {
261 this.enableElement(e, rowSelectionCount > 0);
264 function moveTo(uri) {
265 alert("MoveTo: " + uri);
268 /* contact menu entries */
269 function onContactRowClick(event, node) {
270 loadContact(node.getAttribute('id'));
272 return onRowClick(event);
275 function onContactRowDblClick(event, node) {
276 var contactId = node.getAttribute('id');
278 openContactWindow(URLForFolderID(currentContactFolder)
279 + "/" + contactId + "/edit", contactId);
284 function onMenuEditContact(event) {
285 var contactId = document.menuTarget.getAttribute('id');
287 openContactWindow(URLForFolderID(currentContactFolder)
288 + "/" + contactId + "/edit", contactId);
291 function onMenuWriteToContact(event) {
292 var contactId = document.menuTarget.getAttribute('id');
294 openMailComposeWindow(ApplicationBaseURL + currentContactFolder
295 + "/" + contactId + "/write");
298 function onMenuDeleteContact(event) {
299 uixDeleteSelectedContacts(this);
302 function onToolbarEditSelectedContacts(event) {
303 var contactsList = $('contactsList');
304 var rows = contactsList.getSelectedRowsId();
306 for (var i = 0; i < rows.length; i++) {
307 openContactWindow(URLForFolderID(currentContactFolder)
308 + "/" + rows[i] + "/edit", rows[i]);
314 function onToolbarWriteToSelectedContacts(event) {
315 var contactsList = $('contactsList');
316 var rows = contactsList.getSelectedRowsId();
318 for (var i = 0; i < rows.length; i++)
319 openMailComposeWindow(ApplicationBaseURL + currentContactFolder
320 + "/" + rows[i] + "/write");
325 function uixDeleteSelectedContacts(sender) {
327 var contactsList = $('contactsList');
328 var rows = contactsList.getSelectedRowsId();
330 var contactView = $('contactView');
331 contactView.innerHTML = '';
333 for (var i = 0; i < rows.length; i++) {
334 var url, http, rowElem;
336 /* send AJAX request (synchronously) */
338 url = (URLForFolderID(currentContactFolder) + "/"
339 + rows[i] + "/delete");
340 http = createHTTPClient();
341 http.open("POST", url, false /* not async */);
343 if (http.status != 200) { /* request failed */
350 /* remove from page */
352 /* line-through would be nicer, but hiding is OK too */
353 rowElem = $(rows[i]);
354 rowElem.parentNode.removeChild(rowElem);
358 alert("Could not delete the selected contacts!");
363 function newEmailTo(sender) {
364 var mailto = sanitizeMailTo(sender.parentNode.parentNode.menuTarget.innerHTML);
366 if (mailto.length > 0)
367 openMailComposeWindow("compose?mailto=" + mailto);
369 return false; /* stop following the link */
372 function onHeaderClick(event) {
373 var headerId = this.getAttribute("id");
374 var newSortAttribute;
375 if (headerId == "nameHeader")
376 newSortAttribute = "displayName";
377 else if (headerId == "mailHeader")
378 newSortAttribute = "mail";
379 else if (headerId == "screenNameHeader")
380 newSortAttribute = "screenName";
381 else if (headerId == "orgHeader")
382 newSortAttribute = "org";
383 else if (headerId == "phoneHeader")
384 newSortAttribute = "phone";
386 if (sorting["attribute"] == newSortAttribute)
387 sorting["ascending"] = !sorting["ascending"];
389 sorting["attribute"] = newSortAttribute;
390 sorting["ascending"] = true;
393 refreshCurrentFolder();
395 preventDefault(event);
398 function newContact(sender) {
399 openContactWindow(URLForFolderID(currentContactFolder) + "/new");
401 return false; /* stop following the link */
404 function onFolderSelectionChange() {
405 var folderList = $("contactFolders");
406 var nodes = folderList.getSelectedNodes();
407 $("contactView").innerHTML = '';
409 if (nodes[0].hasClassName("denied")) {
410 var div = $("contactsListContent");
416 $("searchValue").value = "";
418 openContactsFolder(nodes[0].getAttribute("id"));
422 function refreshCurrentFolder() {
423 openContactsFolder(currentContactFolder, true);
426 function onConfirmContactSelection(event) {
427 var tag = this.getAttribute("name");
428 var folderLi = $(currentContactFolder);
429 var currentContactFolderName = folderLi.innerHTML;
430 var selectorList = null;
431 var initialValues = null;
434 var selectorId = selector.getAttribute("id");
435 selectorList = opener.window.document.getElementById('uixselector-'
438 initialValues = selectorList.value;
441 var contactsList = $("contactsList");
442 var rows = contactsList.getSelectedRows();
443 for (i = 0; i < rows.length; i++) {
444 var cid = rows[i].getAttribute("contactid");
445 var cname = '' + rows[i].getAttribute("contactname");
446 var email = '' + rows[i].cells[1].innerHTML;
447 opener.window.addContact(tag, currentContactFolderName + '/' + cname,
451 if (selector && selector.changeNotification
452 && selectorList.value != initialValues)
453 selector.changeNotification("addition");
455 preventDefault(event);
458 function onContactMailTo(node) {
459 return openMailTo(node.innerHTML);
462 function refreshContacts(contactId) {
463 refreshCurrentFolder();
464 cachedContacts[currentContactFolder + "/" + contactId] = null;
465 loadContact(contactId);
470 function onAddressBookNew(event) {
471 createFolder(window.prompt(labels["Name of the Address Book"]),
473 preventDefault(event);
476 function appendAddressBook(name, folder) {
478 folder = accessToSubscribedFolder(folder);
481 var li = document.createElement("li");
482 $("contactFolders").appendChild(li);
483 li.setAttribute("id", folder);
484 li.appendChild(document.createTextNode(name));
485 setEventsOnContactFolder(li);
488 function newFolderCallback(http) {
489 if (http.readyState == 4
490 && http.status == 201) {
491 var name = http.callbackData;
492 appendAddressBook(name, "/" + name);
495 log ("ajax problem 4:" + http.status);
498 function newUserFolderCallback(folderData) {
499 var folder = $(folderData["folder"]);
501 appendAddressBook(folderData["folderName"], folderData["folder"]);
504 function onAddressBookAdd(event) {
505 openUserFolderSelector(newUserFolderCallback, "contact");
507 preventDefault(event);
510 function onFolderUnsubscribeCB(folderId) {
511 var node = $(folderId);
512 node.parentNode.removeChild(node);
513 var personal = $("/personal");
515 onFolderSelectionChange();
518 function onAddressBookRemove(event) {
519 var selector = $("contactFolders");
520 var nodes = selector.getSelectedNodes();
521 if (nodes.length > 0) {
523 var folderId = nodes[0].getAttribute("id");
524 var folderIdElements = folderId.split("_");
525 if (folderIdElements.length > 1)
526 unsubscribeFromFolder(folderId, onFolderUnsubscribeCB, folderId);
528 var abId = folderIdElements[0].substr(1);
529 deletePersonalAddressBook(abId);
530 var personal = $("/personal");
532 onFolderSelectionChange();
536 preventDefault(event);
539 function deletePersonalAddressBook(folderId) {
541 = labels["Are you sure you want to delete the selected address book?"];
542 if (window.confirm(label)) {
543 if (document.deletePersonalABAjaxRequest) {
544 document.deletePersonalABAjaxRequest.aborted = true;
545 document.deletePersonalABAjaxRequest.abort();
547 var url = ApplicationBaseURL + "/" + folderId + "/deleteFolder";
548 document.deletePersonalABAjaxRequest
549 = triggerAjaxRequest(url, deletePersonalAddressBookCallback,
554 function deletePersonalAddressBookCallback(http) {
555 if (http.readyState == 4) {
556 if (isHttpStatus204(http.status)) {
557 var ul = $("contactFolders");
559 var children = ul.childNodesWithTag("li");
562 while (!done && i < children.length) {
563 var currentFolderId = children[i].getAttribute("id").substr(1);
564 if (currentFolderId == http.callbackData) {
565 ul.removeChild(children[i]);
572 document.deletePersonalABAjaxRequest = null;
575 log ("ajax problem 5: " + http.status);
578 function configureDragHandles() {
579 var handle = $("dragHandle");
581 handle.addInterface(SOGoDragHandlesInterface);
582 handle.leftBlock=$("contactFoldersList");
583 handle.rightBlock=$("rightPanel");
586 handle = $("rightDragHandle");
588 handle.addInterface(SOGoDragHandlesInterface);
589 handle.upperBlock=$("contactsListContent");
590 handle.lowerBlock=$("contactView");
594 function lookupDeniedFolders() {
595 var list = $("contactFolders").childNodesWithTag("li");
596 for (var i = 0; i < list.length; i++) {
597 var folderID = list[i].getAttribute("id");
598 var url = URLForFolderID(folderID) + "/canAccessContent";
600 triggerAjaxRequest(url, deniedFoldersLookupCallback, folderID);
604 function deniedFoldersLookupCallback(http) {
605 if (http.readyState == 4) {
606 var denied = ! isHttpStatus204(http.status);
607 var entry = $(http.callbackData);
609 entry.addClassName("denied");
611 entry.removeClassName("denied");
615 function configureAbToolbar() {
616 var toolbar = $("abToolbar");
617 var links = toolbar.childNodesWithTag("a");
618 Event.observe(links[0], "click", onAddressBookNew, false);
619 Event.observe(links[1], "click", onAddressBookAdd, false);
620 Event.observe(links[2], "click", onAddressBookRemove, false);
623 function configureContactFolders() {
624 var contactFolders = $("contactFolders");
625 if (contactFolders) {
626 Event.observe(contactFolders, "mousedown", listRowMouseDownHandler);
627 Event.observe(contactFolders, "click", onFolderSelectionChange);
628 var lis = contactFolders.childNodesWithTag("li");
629 for (var i = 0; i < lis.length; i++)
630 setEventsOnContactFolder(lis[i]);
632 lookupDeniedFolders();
634 var personalFolder = $("/personal");
635 personalFolder.select();
636 openContactsFolder("/personal");
640 function setEventsOnContactFolder(node) {
641 Event.observe(node, "mousedown", listRowMouseDownHandler, false);
642 Event.observe(node, "click", onRowClick, false);
643 Event.observe(node, "contextmenu",
644 onContactFoldersContextMenu.bindAsEventListener(node), false);
647 function onMenuModify(event) {
648 var folders = $("contactFolders");
649 var selected = folders.getSelectedNodes()[0];
651 if (UserLogin == selected.getAttribute("owner")) {
652 var currentName = selected.innerHTML;
653 var newName = window.prompt(labels["Address Book Name"],
655 if (newName && newName.length > 0
656 && newName != currentName) {
657 var url = (URLForFolderID(selected.getAttribute("id"))
658 + "/renameFolder?name=" + escape(newName.utf8encode()));
659 triggerAjaxRequest(url, folderRenameCallback,
660 {node: selected, name: newName});
663 window.alert(clabels["Unable to rename that folder!"]);
666 function folderRenameCallback(http) {
667 if (http.readyState == 4) {
668 if (isHttpStatus204(http.status)) {
669 var dict = http.callbackData;
670 dict["node"].innerHTML = dict["name"];
675 function onMenuSharing(event) {
676 var folders = $("contactFolders");
677 var selected = folders.getSelectedNodes()[0];
678 var title = this.innerHTML;
679 var url = URLForFolderID(selected.getAttribute("id"));
681 openAclWindow(url + "/acls", title);
684 function getMenus() {
686 menus["contactFoldersMenu"] = new Array(onMenuModify, "-", null,
687 null, "-", null, "-",
689 menus["contactMenu"] = new Array(onMenuEditContact, "-",
690 onMenuWriteToContact, null, "-",
691 onMenuDeleteContact);
692 menus["searchMenu"] = new Array(setSearchCriteria);
697 function configureSelectionButtons() {
698 var container = $("contactSelectionButtons");
700 var buttons = container.childNodesWithTag("input");
701 for (var i = 0; i < buttons.length; i++)
702 Event.observe(buttons[i], "click",
703 onConfirmContactSelection.bindAsEventListener(buttons[i]));
707 function initContacts(event) {
708 if (!document.body.hasClassName("popup")) {
709 configureAbToolbar();
712 configureSelectionButtons();
713 configureContactFolders();
717 addEvent(window, 'load', initContacts);