1 /* JavaScript for SOGoMail */
5 var currentMessages = new Array();
6 var maxCachedMessages = 20;
7 var cachedMessages = new Array();
8 var currentMailbox = null;
10 var usersRightsWindowHeight = 320;
11 var usersRightsWindowWidth = 400;
15 function openMessageWindow(msguid, url) {
18 wId += "SOGo_msg_" + msguid;
19 markMailReadInWindow(window, msguid);
21 var msgWin = window.open(url, wId,
22 "width=680,height=520,resizable=1,scrollbars=1,toolbar=0,"
23 + "location=0,directories=0,status=0,menubar=0,copyhistory=0");
25 msgWin.messageId = msguid;
26 msgWin.messageURL = ApplicationBaseURL + currentMailbox + "/" + msguid;
33 function onMessageDoubleClick(event) {
34 resetSelection(window);
35 var msguid = this.parentNode.id.substr(4);
37 return openMessageWindow(msguid,
38 ApplicationBaseURL + currentMailbox + "/"
39 + msguid + "/popupview");
42 function toggleMailSelect(sender) {
45 row.className = sender.checked ? "tableview_selected" : "tableview";
48 function clearSearch(sender) {
49 var searchField = window.$("search");
50 if (searchField) searchField.value="";
56 function validateEditorInput(sender) {
60 field = document.pageform.subject;
61 if (field.value == "")
62 errortext = errortext + labels.error_missingsubject + "\n";
64 if (!UIxRecipientSelectorHasRecipients())
65 errortext = errortext + labels.error_missingrecipients + "\n";
67 if (errortext.length > 0) {
68 alert(labels.error_validationfailed.decodeEntities() + ":\n"
69 + errortext.decodeEntities());
75 function clickedEditorSend(sender) {
76 if (!validateEditorInput(sender))
79 document.pageform.action="send";
80 document.pageform.submit();
81 // if everything is ok, close the window
85 function clickedEditorAttach(sender) {
88 urlstr = "viewAttachments";
89 window.open(urlstr, "SOGo_attach",
90 "width=320,height=320,resizable=1,scrollbars=1,toolbar=0," +
91 "location=0,directories=0,status=0,menubar=0,copyhistory=0");
92 return false; /* stop following the link */
95 function clickedEditorSave(sender) {
96 document.pageform.action="save";
97 document.pageform.submit();
102 function clickedEditorDelete(sender) {
103 document.pageform.action="delete";
104 document.pageform.submit();
110 function openAddressbook(sender) {
113 urlstr = ApplicationBaseURL + "/../Contacts/?popup=YES";
114 var w = window.open(urlstr, "Addressbook",
115 "width=640,height=400,resizable=1,scrollbars=1,toolbar=0,"
116 + "location=0,directories=0,status=0,menubar=0,copyhistory=0");
122 function onMenuSharing(event) {
123 var folderID = document.menuTarget.getAttribute("dataname");
124 var urlstr = URLForFolderID(folderID) + "/acls";
125 event.preventDefault();
127 openAclWindow(urlstr);
130 /* mail list DOM changes */
132 function markMailInWindow(win, msguid, markread) {
135 msgDiv = win.$("div_" + msguid);
138 msgDiv.removeClassName("mailer_unreadmailsubject");
139 msgDiv.addClassName("mailer_readmailsubject");
140 msgDiv = win.$("unreaddiv_" + msguid);
143 msgDiv.setAttribute("class", "mailerUnreadIcon");
144 msgDiv.setAttribute("id", "readdiv_" + msguid);
145 msgDiv.setAttribute("src", ResourcesURL + "/icon_read.gif");
146 msgDiv.setAttribute("onclick", "mailListMarkMessage(this,"
147 + " 'markMessageUnread', " + msguid
150 var title = msgDiv.getAttribute("title-markunread");
152 msgDiv.setAttribute("title", title);
156 msgDiv.removeClassName('mailer_readmailsubject');
157 msgDiv.addClassName('mailer_unreadmailsubject');
158 msgDiv = win.$("readdiv_" + msguid);
161 msgDiv.setAttribute("class", "mailerReadIcon");
162 msgDiv.setAttribute("id", "unreaddiv_" + msguid);
163 msgDiv.setAttribute("src", ResourcesURL + "/icon_unread.gif");
164 msgDiv.setAttribute("onclick", "mailListMarkMessage(this,"
165 + " 'markMessageRead', " + msguid
168 var title = msgDiv.getAttribute("title-markread");
170 msgDiv.setAttribute("title", title);
179 function markMailReadInWindow(win, msguid) {
180 /* this is called by UIxMailView with window.opener */
181 return markMailInWindow(win, msguid, true);
186 function reopenToRemoveLocationBar() {
187 // we cannot really use this, see below at the close comment
188 if (window.locationbar && window.locationbar.visible) {
189 newwin = window.open(window.location.href, "SOGo",
190 "width=800,height=600,resizable=1,scrollbars=1," +
191 "toolbar=0,location=0,directories=0,status=0," +
192 "menubar=0,copyhistory=0");
194 window.close(); // this does only work for windows opened by scripts!
203 /* mail list reply */
205 function openMessageWindowsForSelection(action) {
206 if (document.body.hasClassName("popup"))
207 win = openMessageWindow(window.messageId,
208 window.messageURL + "/" + action /* url */);
210 var messageList = $("messageList");
211 var rows = messageList.getSelectedRowsId();
213 for (var i = 0; i < rows.length; i++)
214 win = openMessageWindow(rows[i].substr(4) /* msguid */,
215 ApplicationBaseURL + currentMailbox
216 + "/" + rows[i].substr(4)
217 + "/" + action /* url */);
223 function mailListMarkMessage(event) {
224 var http = createHTTPClient();
225 var url = ApplicationBaseURL + currentMailbox + "/" + action + "?uid=" + msguid;
228 // TODO: add parameter to signal that we are only interested in OK
229 http.open("POST", url + "&jsonly=1", false /* not async */);
231 if (http.status != 200) {
232 // TODO: refresh page?
233 alert("Message Mark Failed: " + http.statusText);
234 window.location.reload();
237 markMailInWindow(window, msguid, markread);
241 window.location.href = url;
245 /* maillist row highlight */
247 var oldMaillistHighlight = null; // to remember deleted/selected style
249 function ml_highlight(sender) {
250 oldMaillistHighlight = sender.className;
251 if (oldMaillistHighlight == "tableview_highlight")
252 oldMaillistHighlight = null;
253 sender.className = "tableview_highlight";
256 function ml_lowlight(sender) {
257 if (oldMaillistHighlight) {
258 sender.className = oldMaillistHighlight;
259 oldMaillistHighlight = null;
262 sender.className = "tableview";
266 /* folder operations */
268 function ctxFolderAdd(sender) {
271 folderName = prompt("Foldername: ");
272 if (folderName == undefined)
274 if (folderName == "")
277 // TODO: should use a form-POST or AJAX
278 window.location.href = "createFolder?name=" + escape(folderName);
282 function ctxFolderDelete(sender) {
283 if (!confirm("Delete current folder?").decodeEntities())
286 // TODO: should use a form-POST or AJAX
287 window.location.href = "deleteFolder";
291 /* bulk delete of messages */
293 function uixDeleteSelectedMessages(sender) {
296 var messageList = $("messageList");
297 var rowIds = messageList.getSelectedRowsId();
299 for (var i = 0; i < rowIds.length; i++) {
301 var rowId = rowIds[i].substr(4);
302 /* send AJAX request (synchronously) */
304 var messageId = currentMailbox + "/" + rowId;
305 url = ApplicationBaseURL + messageId + "/trash?jsonly=1";
306 http = createHTTPClient();
307 http.open("GET", url, false /* not async */);
309 if (http.status != 200) { /* request failed */
314 deleteCachedMessage(messageId);
315 if (currentMessages[currentMailbox] == rowId) {
316 var div = $('messageContent');
318 currentMessages[currentMailbox] = null;
323 /* remove from page */
325 /* line-through would be nicer, but hiding is OK too */
326 var row = $(rowIds[i]);
327 row.parentNode.removeChild(row);
331 alert("Could not delete " + failCount + " messages!");
336 function moveMessages(rowIds, folder) {
339 for (var i = 0; i < rowIds.length; i++) {
342 /* send AJAX request (synchronously) */
344 var messageId = currentMailbox + "/" + rowIds[i];
345 url = ApplicationBaseURL + messageId + "/move?jsonly=1&tofolder=" + folder;
346 http = createHTTPClient();
347 http.open("GET", url, false /* not async */);
349 if (http.status == 200) {
350 var row = $("row_" + rowIds[i]);
351 row.parentNode.removeChild(row);
352 deleteCachedMessage(messageId);
353 if (currentMessages[currentMailbox] == rowIds[i]) {
354 var div = $('messageContent');
356 currentMessages[currentMailbox] = null;
359 else /* request failed */
362 /* remove from page */
364 /* line-through would be nicer, but hiding is OK too */
368 alert("Could not move " + failCount + " messages!");
373 function onMenuDeleteMessage(event) {
374 uixDeleteSelectedMessages();
375 event.preventDefault();
378 function onMailboxTreeItemClick(event) {
379 var topNode = $("mailboxTree");
380 var mailbox = this.parentNode.getAttribute("dataname");
382 if (topNode.selectedEntry)
383 topNode.selectedEntry.deselect();
385 topNode.selectedEntry = this;
387 var datatype = this.parentNode.getAttribute("datatype");
388 if (datatype == "account" || datatype == "additional") {
389 currentMailbox = mailbox;
390 $("messageContent").innerHTML = "";
391 var body = $("messageList").tBodies[0];
392 for (var i = body.rows.length - 1; i > 0; i--)
396 openMailbox(mailbox);
398 event.preventDefault();
401 function onMailboxMenuMove() {
402 window.alert("unimplemented");
405 function onMailboxMenuCopy() {
406 window.alert("unimplemented");
409 function _refreshWindowMailbox() {
410 openMailbox(currentMailbox, true);
413 function refreshMailbox() {
414 var topWindow = getTopWindow();
416 topWindow._refreshWindowMailbox();
421 function openMailbox(mailbox, reload) {
422 if (mailbox != currentMailbox || reload) {
423 currentMailbox = mailbox;
424 var url = ApplicationBaseURL + mailbox + "/view?noframe=1&desc=1";
425 var mailboxContent = $("mailboxContent");
426 var rightDragHandle = $("rightDragHandle");
427 var messageContent = $("messageContent");
428 messageContent.innerHTML = '';
429 if (mailbox.lastIndexOf("/") == 0) {
430 var url = (ApplicationBaseURL + currentMailbox + "/"
431 + "/view?noframe=1");
432 if (document.messageAjaxRequest) {
433 document.messageAjaxRequest.aborted = true;
434 document.messageAjaxRequest.abort();
436 document.messageAjaxRequest
437 = triggerAjaxRequest(url, messageCallback);
438 mailboxContent.innerHTML = '';
439 mailboxContent.style.visibility = "hidden;";
440 rightDragHandle.style.visibility = "hidden;";
441 messageContent.style.top = "0px;";
443 if (document.messageListAjaxRequest) {
444 document.messageListAjaxRequest.aborted = true;
445 document.messageListAjaxRequest.abort();
447 if (currentMessages[mailbox]) {
448 loadMessage(currentMessages[mailbox]);
449 url += '&pageforuid=' + currentMessages[mailbox];
451 document.messageListAjaxRequest
452 = triggerAjaxRequest(url, messageListCallback,
453 currentMessages[mailbox]);
454 if (mailboxContent.style.visibility == "hidden") {
455 mailboxContent.style.visibility = "visible;";
456 rightDragHandle.style.visibility = "visible;";
457 messageContent.style.top = (rightDragHandle.offsetTop
458 + rightDragHandle.offsetHeight
463 // triggerAjaxRequest(mailbox, 'toolbar', toolbarCallback);
466 function openMailboxAtIndex(event) {
467 var idx = this.getAttribute("idx");
468 var url = ApplicationBaseURL + currentMailbox + "/view?noframe=1&idx=" + idx;
470 if (document.messageListAjaxRequest) {
471 document.messageListAjaxRequest.aborted = true;
472 document.messageListAjaxRequest.abort();
474 document.messageListAjaxRequest
475 = triggerAjaxRequest(url, messageListCallback);
477 event.preventDefault();
480 function messageListCallback(http) {
481 var div = $('mailboxContent');
483 if (http.readyState == 4
484 && http.status == 200) {
485 document.messageListAjaxRequest = null;
486 div.innerHTML = http.responseText;
487 var selected = http.callbackData;
489 var row = $('row_' + selected);
492 configureMessageListEvents();
493 configureSortableTableHeaders();
496 log("problem during ajax request");
499 function onMessageContextMenu(event) {
500 var menu = $('messageListMenu');
501 Event.observe(menu, "hideMenu", onMessageContextMenuHide);
502 popupMenu(event, "messageListMenu", this);
504 var topNode = $('messageList');
505 var selectedNodes = topNode.getSelectedRows();
506 for (var i = 0; i < selectedNodes.length; i++)
507 selectedNodes[i].deselect();
508 topNode.menuSelectedRows = selectedNodes;
509 topNode.menuSelectedEntry = this;
513 function onMessageContextMenuHide(event) {
514 var topNode = $('messageList');
516 if (topNode.menuSelectedEntry) {
517 topNode.menuSelectedEntry.deselect();
518 topNode.menuSelectedEntry = null;
520 if (topNode.menuSelectedRows) {
521 var nodes = topNode.menuSelectedRows;
522 for (var i = 0; i < nodes.length; i++)
524 topNode.menuSelectedRows = null;
528 function onFolderMenuClick(event) {
529 var onhide, menuName;
531 var menutype = this.parentNode.getAttribute("datatype");
533 if (menutype == "inbox") {
534 menuName = "inboxIconMenu";
535 } else if (menutype == "account") {
536 menuName = "accountIconMenu";
537 } else if (menutype == "trash") {
538 menuName = "trashIconMenu";
540 menuName = "mailboxIconMenu";
543 menuName = "mailboxIconMenu";
546 var menu = $(menuName);
547 Event.observe(menu, "hideMenu", onFolderMenuHide);
548 popupMenu(event, menuName, this.parentNode);
550 var topNode = $("mailboxTree");
551 if (topNode.selectedEntry)
552 topNode.selectedEntry.deselect();
553 if (topNode.menuSelectedEntry)
554 topNode.menuSelectedEntry.deselect();
555 topNode.menuSelectedEntry = this;
558 event.preventDefault();
561 function onFolderMenuHide(event) {
562 var topNode = $("mailboxTree");
564 if (topNode.menuSelectedEntry) {
565 topNode.menuSelectedEntry.deselect();
566 topNode.menuSelectedEntry = null;
568 if (topNode.selectedEntry)
569 topNode.selectedEntry.select();
572 function deleteCachedMessage(messageId) {
576 while (counter < cachedMessages.length
578 if (cachedMessages[counter]
579 && cachedMessages[counter]['idx'] == messageId) {
580 cachedMessages.splice(counter, 1);
587 function getCachedMessage(idx) {
591 while (counter < cachedMessages.length
593 if (cachedMessages[counter]
594 && cachedMessages[counter]['idx'] == currentMailbox + '/' + idx)
595 message = cachedMessages[counter];
602 function storeCachedMessage(cachedMessage) {
607 if (cachedMessages.length < maxCachedMessages)
608 oldest = cachedMessages.length;
610 while (cachedMessages[counter]) {
612 || cachedMessages[counter]['time'] < timeOldest) {
614 timeOldest = cachedMessages[counter]['time'];
623 cachedMessages[oldest] = cachedMessage;
626 function onMessageSelectionChange() {
627 var rows = this.getSelectedRowsId();
628 if (rows.length == 1) {
629 var idx = rows[0].substr(4);
631 if (currentMessages[currentMailbox] != idx) {
632 currentMessages[currentMailbox] = idx;
638 function loadMessage(idx) {
639 if (document.messageAjaxRequest) {
640 document.messageAjaxRequest.aborted = true;
641 document.messageAjaxRequest.abort();
644 var cachedMessage = getCachedMessage(idx);
646 if (cachedMessage == null) {
647 var url = (ApplicationBaseURL + currentMailbox + "/"
648 + idx + "/view?noframe=1");
649 document.messageAjaxRequest
650 = triggerAjaxRequest(url, messageCallback, idx);
651 markMailInWindow(window, idx, true);
653 var div = $('messageContent');
654 div.innerHTML = cachedMessage['text'];
655 cachedMessage['time'] = (new Date()).getTime();
656 document.messageAjaxRequest = null;
657 configureLinksInMessage();
661 function configureLinksInMessage() {
662 var messageDiv = $('messageContent');
663 var mailContentDiv = document.getElementsByClassName('mailer_mailcontent',
665 Event.observe(mailContentDiv, "contextmenu", onMessageContentMenu);
666 var anchors = messageDiv.getElementsByTagName('a');
667 for (var i = 0; i < anchors.length; i++)
668 if (anchors[i].href.substring(0,7) == "mailto:") {
669 Event.observe(anchors[i], "click", onEmailAddressClick);
670 Event.observe(anchors[i], "contextmenu", onEmailAddressClick);
673 Event.observe(anchors[i], "click", onMessageAnchorClick);
676 function onMessageContentMenu(event) {
677 popupMenu(event, 'messageContentMenu', this);
680 function onEmailAddressClick(event) {
681 popupMenu(event, 'addressMenu', this);
684 function onMessageAnchorClick (event) {
685 window.open(this.href);
686 event.preventDefault();
689 function messageCallback(http) {
690 var div = $('messageContent');
692 if (http.readyState == 4
693 && http.status == 200) {
694 document.messageAjaxRequest = null;
695 div.innerHTML = http.responseText;
696 configureLinksInMessage();
698 if (http.callbackData) {
699 var cachedMessage = new Array();
700 cachedMessage['idx'] = currentMailbox + '/' + http.callbackData;
701 cachedMessage['time'] = (new Date()).getTime();
702 cachedMessage['text'] = http.responseText;
703 if (cachedMessage['text'].length < 30000)
704 storeCachedMessage(cachedMessage);
708 log("problem during ajax request");
711 function processMailboxMenuAction(mailbox) {
712 var currentNode, upperNode;
716 mailboxName = mailbox.getAttribute('mailboxname');
717 currentNode = mailbox;
721 && !currentNode.hasAttribute('mailboxaction'))
722 currentNode = currentNode.parentNode.parentNode.parentMenuItem;
726 action = currentNode.getAttribute('mailboxaction');
727 // var rows = collectSelectedRows();
728 // var rString = rows.join(', ');
729 // alert("performing '" + action + "' on " + rString
730 // + " to " + mailboxName);
734 var rowSelectionCount = 0;
738 function showElement(e, shouldShow) {
739 e.style.display = shouldShow ? "" : "none";
742 function enableElement(e, shouldEnable) {
746 if(e.hasAttribute("disabled"))
747 e.removeAttribute("disabled");
750 e.setAttribute("disabled", "1");
754 function validateControls() {
756 this.enableElement(e, rowSelectionCount > 0);
759 function moveTo(uri) {
760 alert("MoveTo: " + uri);
763 function deleteSelectedMails() {
766 /* message menu entries */
767 function onMenuOpenMessage(event) {
768 return openMessageWindowsForSelection('popupview');
771 function onMenuReplyToSender(event) {
772 return openMessageWindowsForSelection('reply');
775 function onMenuReplyToAll(event) {
776 return openMessageWindowsForSelection('replyall');
779 function onMenuForwardMessage(event) {
780 return openMessageWindowsForSelection('forward');
784 function newContactFromEmail(event) {
785 var mailto = document.menuTarget.innerHTML;
788 // = /([a-zA-Z][\w\.-]*[a-zA-Z0-9]@[a-zA-Z0-9][\w\.-]*[a-zA-Z0-9]\.[a-zA-Z][a-zA-Z\.]*[a-zA-Z])/g;
789 // emailre.exec(mailto);
790 // email = RegExp.$1;
792 // var namere = /(\w[\w\ _-]+)\ (<|<)/;
794 // if (namere.test(mailto)) {
795 // namere.exec(mailto);
796 // c_name += RegExp.$1;
799 var email = extractEmailAddress(mailto);
800 var c_name = extractEmailName(mailto);
801 if (email.length > 0)
803 var url = UserFolderURL + "Contacts/new?contactEmail=" + email;
805 url += "&contactFN=" + c_name;
806 w = window.open(url, null,
807 "width=546,height=490,resizable=1,scrollbars=1,toolbar=0,"
808 + "location=0,directories=0,status=0,menubar=0,copyhistory=0");
812 return false; /* stop following the link */
815 function newEmailTo(sender) {
816 return openMailTo(document.menuTarget.innerHTML);
819 function expandUpperTree(node) {
820 var currentNode = node.parentNode;
822 while (currentNode.className != "dtree") {
823 if (currentNode.className == 'clip') {
824 var id = currentNode.getAttribute("id");
825 var number = parseInt(id.substr(2));
827 var cn = mailboxTree.aNodes[number];
828 mailboxTree.nodeStatus(1, number, cn._ls);
831 currentNode = currentNode.parentNode;
835 function onHeaderClick(event) {
836 if (document.messageListAjaxRequest) {
837 document.messageListAjaxRequest.aborted = true;
838 document.messageListAjaxRequest.abort();
840 url = ApplicationBaseURL + currentMailbox + "/" + this.link;
841 if (!this.link.match(/noframe=/))
843 document.messageListAjaxRequest
844 = triggerAjaxRequest(url, messageListCallback);
846 event.preventDefault();
849 function onSearchFormSubmit() {
850 log("search not implemented");
855 function pouetpouet(event) {
856 window.alert("pouet pouet");
859 var mailboxSpanAcceptType = function(type) {
860 return (type == "mailRow");
863 var mailboxSpanEnter = function() {
864 this.addClassName("_dragOver");
867 var mailboxSpanExit = function() {
868 this.removeClassName("_dragOver");
871 var mailboxSpanDrop = function(data) {
875 var folder = this.parentNode.parentNode.getAttribute("dataname");
876 if (folder != currentMailbox)
877 success = (moveMessages(data, folder) == 0);
885 var plusSignEnter = function() {
886 var nodeNr = parseInt(this.id.substr(2));
887 if (!mailboxTree.aNodes[nodeNr]._io)
888 this.plusSignTimer = setTimeout("openPlusSign('" + nodeNr + "');", 1000);
891 var plusSignExit = function() {
892 if (this.plusSignTimer) {
893 clearTimeout(this.plusSignTimer);
894 this.plusSignTimer = null;
898 function openPlusSign(nodeNr) {
899 mailboxTree.nodeStatus(1, nodeNr, mailboxTree.aNodes[nodeNr]._ls);
900 mailboxTree.aNodes[nodeNr]._io = 1;
901 this.plusSignTimer = null;
904 var messageListGhost = function () {
905 var newDiv = document.createElement("div");
906 // newDiv.style.width = "25px;";
907 // newDiv.style.height = "25px;";
908 newDiv.style.backgroundColor = "#aae;";
909 newDiv.style.border = "2px solid #a3a;";
910 newDiv.style.padding = "5px;";
911 newDiv.ghostOffsetX = 10;
912 newDiv.ghostOffsetY = 5;
914 var newImg = document.createElement("img");
915 newImg.src = ResourcesURL + "/message-mail.png";
917 var list = $("messageList");
918 var count = list.getSelectedRows().length;
919 newDiv.appendChild(newImg);
920 newDiv.appendChild(document.createElement("br"));
921 newDiv.appendChild(document.createTextNode(count + " messages..."));
926 var messageListData = function(type) {
927 var rows = this.parentNode.parentNode.getSelectedRowsId();
928 var msgIds = new Array();
929 for (var i = 0; i < rows.length; i++)
930 msgIds.push(rows[i].substr(4));
935 function configureMessageListEvents() {
936 var messageList = $("messageList");
938 Event.observe(messageList, "selectionchange", onMessageSelectionChange);
939 var rows = messageList.tBodies[0].rows;
941 if (rows.length > 1) {
942 if (rows[start].cells[0].hasClassName("tbtv_headercell"))
944 if (rows[start].cells[0].hasClassName("tbtv_navcell")) {
945 log("start:" + start);
946 var anchors = $(rows[start].cells[0]).childNodesWithTag("a");
947 log("nr anchors: " + anchors.length);
948 for (var i = 0; i < anchors.length; i++)
949 Event.observe(anchors[i], "click", openMailboxAtIndex);
952 for (var i = start; i < rows.length; i++) {
953 Event.observe(rows[i], "mousedown", onRowClick);
954 Event.observe(rows[i], "contextmenu", onMessageContextMenu);
956 rows[i].dndTypes = function() { return new Array("mailRow"); };
957 rows[i].dndGhost = messageListGhost;
958 rows[i].dndDataForType = messageListData;
959 document.DNDManager.registerSource(rows[i]);
961 for (var j = 0; j < rows[i].cells.length; j++) {
962 var cell = rows[i].cells[j];
963 Event.observe(cell, "mousedown", listRowMouseDownHandler);
964 if (j == 2 || j == 3 || j == 5)
965 Event.observe(cell, "dblclick", onMessageDoubleClick);
967 var img = cell.childNodesWithTag("img")[0];
968 Event.observe(img, "click", mailListMarkMessage);
976 function configureDragHandles() {
977 var handle = $("verticalDragHandle");
979 handle.addInterface(SOGoDragHandlesInterface);
980 handle.leftBlock=$("leftPanel");
981 handle.rightBlock=$("rightPanel");
984 handle = $("rightDragHandle");
986 handle.addInterface(SOGoDragHandlesInterface);
987 handle.upperBlock=$("mailboxContent");
988 handle.lowerBlock=$("messageContent");
994 // log("MailerUI initDnd");
996 var tree = $("mailboxTree");
998 var images = tree.getElementsByTagName("img");
999 for (var i = 0; i < images.length; i++) {
1000 if (images[i].id[0] == 'j') {
1001 images[i].dndAcceptType = mailboxSpanAcceptType;
1002 images[i].dndEnter = plusSignEnter;
1003 images[i].dndExit = plusSignExit;
1004 document.DNDManager.registerDestination(images[i]);
1007 var nodes = document.getElementsByClassName("nodeName", tree);
1008 for (var i = 0; i < nodes.length; i++) {
1009 nodes[i].dndAcceptType = mailboxSpanAcceptType;
1010 nodes[i].dndEnter = mailboxSpanEnter;
1011 nodes[i].dndExit = mailboxSpanExit;
1012 nodes[i].dndDrop = mailboxSpanDrop;
1013 document.DNDManager.registerDestination(nodes[i]);
1020 function refreshContacts() {
1023 function openInbox(node) {
1025 openMailbox(node.parentNode.getAttribute("dataname"));
1026 var tree = $("mailboxTree");
1027 tree.selectedEntry = node;
1032 function configureSearchField() {
1033 var searchValue = $("searchValue");
1035 Event.observe(searchValue, "mousedown", onSearchMouseDown);
1036 Event.observe(searchValue, "click", popupSearchMenu);
1037 Event.observe(searchValue, "blur", onSearchBlur);
1038 Event.observe(searchValue, "focus", onSearchFocus);
1039 Event.observe(searchValue, "keydown", onSearchKeyDown);
1042 function initMailer(event) {
1043 if (!document.body.hasClassName("popup")) {
1044 configureSearchField();
1045 configureMessageListEvents();
1047 currentMailbox = "/" + accounts[0] + "/INBOX";
1052 function initMailboxTree() {
1053 mailboxTree = new dTree("mailboxTree");
1054 mailboxTree.config.folderLinks = true;
1055 mailboxTree.config.hideRoot = true;
1057 mailboxTree.icon.root = ResourcesURL + "/tbtv_account_17x17.gif";
1058 mailboxTree.icon.folder = ResourcesURL + "/tbtv_leaf_corner_17x17.gif";
1059 mailboxTree.icon.folderOpen = ResourcesURL + "/tbtv_leaf_corner_17x17.gif";
1060 mailboxTree.icon.node = ResourcesURL + "/tbtv_leaf_corner_17x17.gif";
1061 mailboxTree.icon.line = ResourcesURL + "/tbtv_line_17x17.gif";
1062 mailboxTree.icon.join = ResourcesURL + "/tbtv_junction_17x17.gif";
1063 mailboxTree.icon.joinBottom = ResourcesURL + "/tbtv_corner_17x17.gif";
1064 mailboxTree.icon.plus = ResourcesURL + "/tbtv_plus_17x17.gif";
1065 mailboxTree.icon.plusBottom = ResourcesURL + "/tbtv_corner_plus_17x17.gif";
1066 mailboxTree.icon.minus = ResourcesURL + "/tbtv_minus_17x17.gif";
1067 mailboxTree.icon.minusBottom = ResourcesURL + "/tbtv_corner_minus_17x17.gif";
1068 mailboxTree.icon.nlPlus = ResourcesURL + "/tbtv_corner_plus_17x17.gif";
1069 mailboxTree.icon.nlMinus = ResourcesURL + "/tbtv_corner_minus_17x17.gif";
1070 mailboxTree.icon.empty = ResourcesURL + "/empty.gif";
1072 mailboxTree.add(0, -1, '');
1074 mailboxTree.pendingRequests = mailAccounts.length;
1075 for (var i = 0; i < mailAccounts.length; i++) {
1076 var url = ApplicationBaseURL + "/" + mailAccounts[i] + "/mailboxes";
1077 triggerAjaxRequest(url, onLoadMailboxesCallback, mailAccounts[i]);
1081 function updateMailboxTreeInPage() {
1082 $("folderTreeContent").innerHTML = mailboxTree;
1084 var inboxFound = false;
1085 var tree = $("mailboxTree");
1086 var nodes = document.getElementsByClassName("node", tree);
1087 for (i = 0; i < nodes.length; i++) {
1088 Event.observe(nodes[i], "click", onMailboxTreeItemClick.bindAsEventListener(nodes[i]));
1089 Event.observe(nodes[i], "contextmenu", onFolderMenuClick.bindAsEventListener(nodes[i]));
1091 && nodes[i].parentNode.getAttribute("datatype") == "inbox") {
1092 openInbox(nodes[i]);
1098 function mailboxMenuNode(type, name) {
1099 var newNode = document.createElement("li");
1100 var icon = MailerUIdTreeExtension.folderIcons[type];
1102 icon = "tbtv_leaf_corner_17x17.gif";
1103 var image = document.createElement("img");
1104 image.src = ResourcesURL + "/" + icon;
1105 newNode.appendChild(image);
1106 newNode.appendChild(document.createTextNode(" " + name));
1111 function generateMenuForMailbox(mailbox, prefix, callback) {
1112 var menuDIV = document.createElement("div");
1113 menuDIV.addClassName("menu");
1114 menuDIV.setAttribute("id", prefix + "Submenu");
1115 var menu = document.createElement("ul");
1116 menuDIV.appendChild(menu);
1118 var callbacks = new Array();
1119 if (mailbox.type != "account") {
1120 var newNode = document.createElement("li");
1121 newNode.mailbox = mailbox;
1122 newNode.appendChild(document.createTextNode("coucou"));
1123 menu.appendChild(newNode);
1124 menu.appendChild(document.createElement("li"));
1125 callbacks.push(callback);
1126 callbacks.push("-");
1129 var submenuCount = 0;
1130 for (var i = 0; i < mailbox.children.length; i++) {
1131 var child = mailbox.children[i];
1132 var newNode = mailboxMenuNode(child.type, child.name);
1133 menu.appendChild(newNode);
1134 if (child.children.length > 0) {
1135 var newPrefix = prefix + submenuCount;
1136 var newSubmenu = generateMenuForMailbox(child,
1139 document.body.appendChild(newSubmenu);
1140 callbacks.push(newPrefix + "Submenu");
1144 newNode.mailbox = child;
1145 callbacks.push(callback);
1148 initMenu(menuDIV, callbacks);
1153 function updateMailboxMenus() {
1154 var mailboxActions = { move: onMailboxMenuMove,
1155 copy: onMailboxMenuCopy };
1157 for (key in mailboxActions) {
1158 var menuId = key + "MailboxMenu";
1159 var menuDIV = $(menuId);
1161 menuDIV.parentNode.removeChild(menuDIV);
1162 menuDIV = document.createElement("div");
1163 menuDIV.addClassName("menu");
1164 menuDIV.setAttribute("id", menuId);
1165 var menu = document.createElement("ul");
1166 menuDIV.appendChild(menu);
1168 var submenuIds = new Array();
1169 for (var i = 0; i < mailAccounts.length; i++) {
1170 var menuEntry = mailboxMenuNode("account", mailAccounts[i]);
1171 menu.appendChild(menuEntry);
1172 var mailbox = accounts[mailAccounts[i]];
1173 var newSubmenu = generateMenuForMailbox(mailbox,
1174 key, mailboxActions[key]);
1175 document.body.appendChild(newSubmenu);
1176 submenuIds.push(newSubmenu.getAttribute("id"));
1178 initMenu(menuDIV, submenuIds);
1180 document.body.appendChild(menuDIV);
1184 function onLoadMailboxesCallback(http) {
1185 if (http.readyState == 4
1186 && http.status == 200) {
1187 var newAccount = buildMailboxes(http.callbackData,
1189 accounts[http.callbackData] = newAccount;
1190 mailboxTree.addMailAccount(newAccount);
1191 mailboxTree.pendingRequests--;
1192 if (!mailboxTree.pendingRequests) {
1193 updateMailboxTreeInPage();
1194 updateMailboxMenus();
1198 // var tree = $("mailboxTree");
1199 // var treeNodes = document.getElementsByClassName("dTreeNode", tree);
1201 // while (i < treeNodes.length
1202 // && treeNodes[i].getAttribute("dataname") != currentMailbox)
1204 // if (i < treeNodes.length) {
1205 // // log("found mailbox");
1206 // var links = document.getElementsByClassName("node", treeNodes[i]);
1207 // if (tree.selectedEntry)
1208 // tree.selectedEntry.deselect();
1209 // links[0].select();
1210 // tree.selectedEntry = links[0];
1211 // expandUpperTree(links[0]);
1215 function buildMailboxes(accountName, encoded) {
1216 var account = new Mailbox("account", accountName);
1217 var data = encoded.evalJSON(true);
1218 for (var i = 0; i < data.length; i++) {
1219 var currentNode = account;
1220 var names = data[i].path.split("/");
1221 for (var j = 1; j < (names.length - 1); j++) {
1222 var node = currentNode.findMailboxByName(names[j]);
1224 node = new Mailbox("additional", names[j]);
1225 currentNode.addMailbox(node);
1229 var basename = names[names.length-1];
1230 var leaf = currentNode.findMailboxByName(basename);
1232 leaf.type = data[i].type;
1234 leaf = new Mailbox(data[i].type, basename);
1235 currentNode.addMailbox(leaf);
1242 function onMenuCreateFolder(event) {
1243 var name = window.prompt(labels["Name :"].decodeEntities(), "");
1244 if (name && name.length > 0) {
1245 var folderID = document.menuTarget.getAttribute("dataname");
1246 var urlstr = URLForFolderID(folderID) + "/createFolder?name=" + name;
1247 triggerAjaxRequest(urlstr, folderOperationCallback);
1251 function onMenuRenameFolder(event) {
1252 var name = window.prompt(labels["Enter the new name of your folder :"]
1255 if (name && name.length > 0) {
1256 var folderID = document.menuTarget.getAttribute("dataname");
1257 var urlstr = URLForFolderID(folderID) + "/renameFolder?name=" + name;
1258 triggerAjaxRequest(urlstr, folderOperationCallback);
1262 function onMenuDeleteFolder(event) {
1263 var answer = window.confirm(labels["Do you really want to move this folder into the trash ?"].decodeEntities());
1265 var folderID = document.menuTarget.getAttribute("dataname");
1266 var urlstr = URLForFolderID(folderID) + "/deleteFolder";
1267 triggerAjaxRequest(urlstr, folderOperationCallback);
1271 function onMenuEmptyTrash(event) {
1272 var folderID = document.menuTarget.getAttribute("dataname");
1273 var urlstr = URLForFolderID(folderID) + "/emptyTrash";
1274 triggerAjaxRequest(urlstr, folderOperationCallback);
1277 function folderOperationCallback(http) {
1278 if (http.readyState == 4
1279 && http.status == 204)
1282 window.alert(labels["Operation failed"].decodeEntities());
1285 function getMenus() {
1287 menus["accountIconMenu"] = new Array(null, null, onMenuCreateFolder, null,
1289 menus["inboxIconMenu"] = new Array(null, null, null, "-", null,
1290 onMenuCreateFolder, null, "-", null,
1292 menus["trashIconMenu"] = new Array(null, null, null, "-", null,
1293 onMenuCreateFolder, null,
1294 onMenuEmptyTrash, "-", null,
1296 menus["mailboxIconMenu"] = new Array(null, null, null, "-", null,
1299 null, onMenuDeleteFolder, "-", null,
1301 menus["addressMenu"] = new Array(newContactFromEmail, newEmailTo, null);
1302 menus["messageListMenu"] = new Array(onMenuOpenMessage, "-",
1303 onMenuReplyToSender,
1305 onMenuForwardMessage, null,
1306 "-", "moveMailboxMenu",
1307 "copyMailboxMenu", "label-menu",
1308 "mark-menu", "-", null, null,
1309 null, onMenuDeleteMessage);
1310 menus["messageContentMenu"] = new Array(onMenuReplyToSender,
1312 onMenuForwardMessage,
1313 null, "moveMailboxMenu",
1315 "-", "label-menu", "mark-menu",
1318 onMenuDeleteMessage);
1319 menus["label-menu"] = new Array(null, "-", null , null, null, null , null,
1321 menus["mark-menu"] = new Array(null, null, null, null, "-", null, "-",
1327 Event.observe(window, "load", initMailer);
1329 function Mailbox(type, name) {
1332 this.parentFolder = null;
1333 this.children = new Array();
1337 Mailbox.prototype.dump = function(indent) {
1340 log(" ".repeat(indent) + this.name);
1341 for (var i = 0; i < this.children.length; i++) {
1342 this.children[i].dump(indent + 2);
1346 Mailbox.prototype.findMailboxByName = function(name) {
1350 while (!mailbox && i <this.children.length)
1351 if (this.children[i].name == name)
1352 mailbox = this.children[i];
1359 Mailbox.prototype.addMailbox = function(mailbox) {
1360 mailbox.parentFolder = this;
1361 this.children.push(mailbox);