271 lines
9.1 KiB
JavaScript
271 lines
9.1 KiB
JavaScript
var d;
|
|
|
|
function onSearchFormSubmit(filterPanel) {
|
|
var searchValue = filterPanel.down('[name="search"]');
|
|
var encodedValue = encodeURI(searchValue.value);
|
|
|
|
if (encodedValue.blank()) {
|
|
checkAjaxRequestsState();
|
|
}
|
|
else {
|
|
var url = (UserFolderURL
|
|
+ "usersSearch?search=" + encodedValue);
|
|
if (document.userFoldersRequest) {
|
|
document.userFoldersRequest.aborted = true;
|
|
document.userFoldersRequest.abort();
|
|
}
|
|
if (encodedValue.trim().length > minimumSearchLength) {
|
|
startAnimation($("pageContent"), filterPanel);
|
|
document.userFoldersRequest
|
|
= triggerAjaxRequest(url, usersSearchCallback);
|
|
}
|
|
}
|
|
|
|
return false;
|
|
}
|
|
|
|
function usersSearchCallback(http) {
|
|
document.userFoldersRequest = null;
|
|
var div = $("folders");
|
|
if (http.status == 200) {
|
|
var response = http.responseText.evalJSON();
|
|
buildUsersTree(div, response);
|
|
}
|
|
else if (http.status == 404)
|
|
div.update();
|
|
}
|
|
|
|
function addUserLineToTree(tree, parent, line) {
|
|
// line[0] = uid
|
|
// line[1] = cn
|
|
// line[2] = email
|
|
// line[3] = 1 if it's a group
|
|
// line[4] = contact info
|
|
var icon = ResourcesURL + '/busy.gif';
|
|
|
|
var email = line[1] + " <" + line[2] + ">";
|
|
if (line[4] && !line[4].empty())
|
|
email += ", " + line[4].split("\n").join("; "); // extra contact info
|
|
var icon_card = 'abcard.png';
|
|
var datatype = 'user';
|
|
if (line[3]) {
|
|
icon_card = 'ablist.png';
|
|
datatype = 'group';
|
|
}
|
|
tree.add(parent, 0, email, 0, '#', line[0], datatype,
|
|
'', '',
|
|
ResourcesURL + '/' + icon_card,
|
|
ResourcesURL + '/' + icon_card);
|
|
if (window.opener.userFolderType != "user") {
|
|
tree.add(parent + 1, parent, _("Please wait..."), 0, '#', null,
|
|
null, '', '', icon, icon);
|
|
}
|
|
}
|
|
|
|
function buildUsersTree(treeDiv, response) {
|
|
if (!treeDiv.clean) {
|
|
var oldD = $("d"); // the folders tree
|
|
if (oldD) {
|
|
oldD.remove();
|
|
delete d;
|
|
}
|
|
treeDiv.clean = true;
|
|
$("addButton").addClassName("disabled");
|
|
}
|
|
|
|
d = new dTree("d");
|
|
d.config.hideRoot = true;
|
|
d.icon.root = ResourcesURL + '/tbtv_account_17x17.gif';
|
|
d.icon.folder = ResourcesURL + '/tbtv_leaf_corner_17x17.png';
|
|
d.icon.folderOpen = ResourcesURL + '/tbtv_leaf_corner_17x17.png';
|
|
d.icon.node = ResourcesURL + '/tbtv_leaf_corner_17x17.png';
|
|
d.icon.line = ResourcesURL + '/tbtv_line_17x22.png';
|
|
d.icon.join = ResourcesURL + '/tbtv_junction_17x22.png';
|
|
d.icon.joinBottom = ResourcesURL + '/tbtv_corner_17x22.png';
|
|
d.icon.plus = ResourcesURL + '/tbtv_plus_17x22.png';
|
|
d.icon.plusBottom = ResourcesURL + '/tbtv_corner_plus_17x22.png';
|
|
d.icon.minus = ResourcesURL + '/tbtv_minus_17x22.png';
|
|
d.icon.minusBottom = ResourcesURL + '/tbtv_corner_minus_17x22.png';
|
|
d.icon.nlPlus = ResourcesURL + '/tbtv_corner_plus_17x22.png';
|
|
d.icon.nlMinus = ResourcesURL + '/tbtv_corner_minus_17x22.png';
|
|
d.icon.empty = ResourcesURL + '/empty.gif';
|
|
d.preload();
|
|
d.add(0, -1, '');
|
|
|
|
var isUserDialog = (window.opener.userFolderType == "user");
|
|
var multiplier = ((isUserDialog) ? 1 : 2);
|
|
|
|
if (response.length > 0) {
|
|
for (var i = 0; i < response.length; i++)
|
|
addUserLineToTree(d, 1 + i * multiplier, response[i]);
|
|
treeDiv.appendChild(d.domObject ());
|
|
treeDiv.clean = false;
|
|
for (var i = 0; i < response.length; i++) {
|
|
if (!isUserDialog) {
|
|
var toggle = $("tgd" + (1 + i * 2));
|
|
toggle.on("click", onUserNodeToggle);
|
|
}
|
|
var sd = $("sd" + (1 + i * multiplier));
|
|
sd.on("click", onTreeItemClick);
|
|
}
|
|
}
|
|
else {
|
|
$$('[name="search"]').first().addClassName("notfound");
|
|
}
|
|
}
|
|
|
|
function onUserNodeToggle(event) {
|
|
this.stopObserving("click", onUserNodeToggle);
|
|
|
|
var person = this.parentNode.getAttribute("dataname").unescapeHTML();
|
|
|
|
var url = (UserFolderURLForUser(person) + "foldersSearch"
|
|
+ "?type=" + window.opener.userFolderType);
|
|
var nodeId = this.getAttribute("id").substr(3);
|
|
triggerAjaxRequest(url, foldersSearchCallback,
|
|
{ nodeId: nodeId, user: person });
|
|
}
|
|
|
|
function onTreeItemClick(event) {
|
|
preventDefault(event);
|
|
|
|
var topNode = $("d");
|
|
if (topNode.selectedEntry)
|
|
topNode.selectedEntry.deselect();
|
|
this.selectElement();
|
|
topNode.selectedEntry = this;
|
|
|
|
if (window.opener.userFolderType == "user")
|
|
$("addButton").removeClassName("disabled");
|
|
else {
|
|
var dataname = this.parentNode.getAttribute("dataname");
|
|
if (!dataname)
|
|
dataname = "";
|
|
if (dataname.indexOf(":") == -1)
|
|
$("addButton").addClassName("disabled");
|
|
else
|
|
$("addButton").removeClassName("disabled");
|
|
};
|
|
}
|
|
|
|
function foldersSearchCallback(http) {
|
|
if (http.status == 200) {
|
|
var response = http.responseText;
|
|
var nodeId = parseInt(http.callbackData["nodeId"]);
|
|
|
|
var dd = $("dd" + (nodeId + 2));
|
|
var indentValue = (dd ? 1 : 0);
|
|
d.aIndent.push(indentValue);
|
|
|
|
var dd = $("dd" + nodeId);
|
|
var folders = response.evalJSON();
|
|
if (folders.length) {
|
|
var user = http.callbackData["user"];
|
|
|
|
dd.innerHTML = '';
|
|
for (var i = 0; i < folders.length-1; i++)
|
|
dd.appendChild(addFolderBranchToTree(d, user, folders[i], nodeId, i+1, false));
|
|
dd.appendChild(addFolderBranchToTree(d, user, folders[folders.length-1], nodeId,
|
|
folders.length, true));
|
|
//dd.update(str);
|
|
for (var i = 0; i < folders.length; i++) {
|
|
var sd = $("sd" + (nodeId + i + 1));
|
|
sd.on("click", onTreeItemClick);
|
|
}
|
|
}
|
|
else {
|
|
dd.innerHTML = '';
|
|
dd.appendChild(addFolderNotFoundNode(d, nodeId, null));
|
|
var sd = $("sd" + (nodeId + 1));
|
|
sd.on("click", onTreeItemClick);
|
|
}
|
|
|
|
d.aIndent.pop();
|
|
}
|
|
}
|
|
|
|
function addFolderBranchToTree(tree, user, folder, nodeId, subId, isLast) {
|
|
var icon = ResourcesURL + '/';
|
|
if (folder.type == 'Contact')
|
|
icon += 'tb-mail-addressbook-flat-16x16.png';
|
|
else
|
|
icon += 'calendar-folder-16x16.png';
|
|
var folderId = user + ":" + folder.name.substr(1);
|
|
|
|
// We sanitize the value to avoid XSS issues
|
|
var name = folder.displayName.escapeHTML();
|
|
var node = new dTreeNode(subId, nodeId, name, 0, '#', folderId,
|
|
folder.type + '-folder', '', '', icon, icon);
|
|
node._ls = isLast;
|
|
|
|
var content = tree.node(node, (nodeId + subId), null);
|
|
content._formattedName = folder.formattedName;
|
|
|
|
return content;
|
|
}
|
|
|
|
function addFolderNotFoundNode(tree, nodeId) {
|
|
var icon = ResourcesURL + '/dot.png';
|
|
var node = new dTreeNode(1, nodeId, _("No possible subscription"), 0, '#',
|
|
null, null, '', '', icon, icon);
|
|
node._ls = true;
|
|
return tree.node(node, (nodeId + 1));
|
|
}
|
|
|
|
function onConfirmFolderSelection(event) {
|
|
if (!this.hasClassName("disabled")) {
|
|
var topNode = $("d");
|
|
if (topNode && topNode.selectedEntry) {
|
|
var node = topNode.selectedEntry.parentNode;
|
|
var folder = node.getAttribute("dataname");
|
|
var type = node.getAttribute("datatype");
|
|
var folderName;
|
|
if (window.opener.userFolderType == "user") {
|
|
var resource = $(topNode.selectedEntry).down("SPAN.nodeName");
|
|
var description = (resource.innerHTML
|
|
.replace("<", "<", "g")
|
|
.replace(">", ">", "g"));
|
|
folderName = description.replace(/>,.*$/, ">", "g");
|
|
}
|
|
else {
|
|
folderName = node._formattedName;
|
|
}
|
|
var data = { folderName: folderName, folder: folder, type: type, window: window };
|
|
if (parent$(accessToSubscribedFolder(folder)))
|
|
window.alert(_("You have already subscribed to that folder!"));
|
|
else
|
|
window.opener.subscribeToFolder(window.opener.userFolderCallback, data);
|
|
this.blur(); // required by IE
|
|
}
|
|
}
|
|
}
|
|
|
|
function onFolderSearchKeyDown(event) {
|
|
if (event.keyCode == Event.KEY_BACKSPACE
|
|
|| IsCharacterKey(event.keyCode)) {
|
|
$(this).removeClassName("notfound");
|
|
var div = $("folders");
|
|
if (!div.clean) {
|
|
var oldD = $("d"); // the folders tree
|
|
if (oldD) {
|
|
oldD.remove();
|
|
delete d;
|
|
}
|
|
div.clean = true;
|
|
$("addButton").addClassName("disabled");
|
|
}
|
|
}
|
|
}
|
|
|
|
function initUserFoldersWindow() {
|
|
var searchValue = $$('[name="search"]').first();
|
|
searchValue.on("keydown", onFolderSearchKeyDown);
|
|
|
|
$("addButton").on("click", onConfirmFolderSelection);
|
|
$("doneButton").on("click", onCloseButtonClick);
|
|
|
|
searchValue.focus();
|
|
}
|
|
|
|
document.observe("dom:loaded", initUserFoldersWindow);
|