moodle/group/clientlib.js

176 lines
5.8 KiB
JavaScript
Raw Normal View History

/**
* Client-side JavaScript for group management interface.
* @author vy-shane AT moodle.com
* @license http://www.gnu.org/copyleft/gpl.html GNU Public License
* @package groups
*/
/**
* Class UpdatableGroupsCombo
*/
function UpdatableGroupsCombo(wwwRoot, courseId) {
this.wwwRoot = wwwRoot;
this.courseId = courseId;
2007-01-22 06:06:08 +00:00
this.connectCallback = {
2007-01-23 06:20:47 +00:00
success: function(o) {
if (o.responseText !== undefined) {
var groupsComboEl = document.getElementById("groups");
var membersComboEl = document.getElementById("members");
if (membersComboEl) {
// Clear the members combo box.
while (membersComboEl.firstChild) {
membersComboEl.removeChild(membersComboEl.firstChild);
}
}
2007-01-22 06:57:40 +00:00
if (groupsComboEl && o.responseText) {
2007-01-23 06:20:47 +00:00
var groups = eval("("+o.responseText+")");
2007-01-22 06:57:40 +00:00
// Populate the groups combo box.
for (var i=0; i<groups.length; i++) {
var optionEl = document.createElement("option");
optionEl.setAttribute("value", groups[i].id);
optionEl.title = groups[i].name;
2007-01-22 06:57:40 +00:00
optionEl.innerHTML = groups[i].name;
groupsComboEl.appendChild(optionEl);
}
}
}
// Remove the loader gif image.
2007-01-22 06:06:08 +00:00
removeLoaderImgs("groupsloader", "groupslabel");
2007-01-22 06:57:40 +00:00
},
failure: function(o) {
removeLoaderImgs("membersloader", "memberslabel");
2007-01-23 06:20:47 +00:00
this.currentTransId = null;
}
2007-01-23 06:20:47 +00:00
2007-01-22 06:06:08 +00:00
};
2007-01-22 06:57:40 +00:00
// Add onchange event to groups combo box.
2007-01-23 06:20:47 +00:00
// Okay, this is not working in IE. The onchange is never fired...
// I'm hard coding the onchange in ../index.php. Not ideal, but it works
// then. vyshane AT moodle DOT com.
/*
2007-01-22 06:57:40 +00:00
groupsComboEl = document.getElementById("groups");
if (groupsComboEl) {
groupsComboEl.setAttribute("onchange", "membersCombo.refreshMembers(this.options[this.selectedIndex].value);");
}
2007-01-23 06:20:47 +00:00
*/
// Hide the updategroups input since AJAX will take care of this.
YAHOO.util.Dom.setStyle("updategroups", "display", "none");
}
/**
* Class UpdatableMembersCombo
*/
function UpdatableMembersCombo(wwwRoot, courseId) {
this.wwwRoot = wwwRoot;
this.courseId = courseId;
2007-01-22 06:06:08 +00:00
this.connectCallback = {
success: function(o) {
if (o.responseText !== undefined) {
var selectEl = document.getElementById("members");
2007-01-22 06:57:40 +00:00
if (selectEl && o.responseText) {
2007-01-23 06:20:47 +00:00
var members = eval("("+o.responseText+")");
2007-01-22 06:57:40 +00:00
// Clear the members combo box.
if (selectEl) {
while (selectEl.firstChild) {
selectEl.removeChild(selectEl.firstChild);
}
}
2007-01-22 06:57:40 +00:00
// Populate the members combo box.
for (var i=0; i<members.length; i++) {
var optionEl = document.createElement("option");
optionEl.setAttribute("value", members[i].id);
optionEl.title = members[i].name;
optionEl.innerHTML = members[i].name;
2007-01-22 06:57:40 +00:00
selectEl.appendChild(optionEl);
}
}
}
// Remove the loader gif image.
2007-01-22 06:06:08 +00:00
removeLoaderImgs("membersloader", "memberslabel");
2007-01-22 06:57:40 +00:00
},
failure: function(o) {
removeLoaderImgs("membersloader", "memberslabel");
}
2007-01-23 06:20:47 +00:00
2007-01-22 06:06:08 +00:00
};
// Hide the updatemembers input since AJAX will take care of this.
YAHOO.util.Dom.setStyle("updatemembers", "display", "none");
}
/**
* When a group is selected, we need to update the members.
* The Add/Remove Users button also needs to be disabled/enabled
* depending on whether or not a group is selected
*/
UpdatableMembersCombo.prototype.refreshMembers = function (groupId) {
// Add the loader gif image.
createLoaderImg("membersloader", "memberslabel", this.wwwRoot);
// Update the label.
var selectEl = document.getElementById("groups");
var spanEl = document.getElementById("thegroup");
if (selectEl && selectEl.selectedIndex >= 0) {
spanEl.innerHTML = selectEl.options[selectEl.selectedIndex].title;
}
2007-01-22 06:57:40 +00:00
// Clear the members combo box.
selectEl = document.getElementById("members");
2007-01-22 06:57:40 +00:00
if (selectEl) {
while (selectEl.firstChild) {
selectEl.removeChild(selectEl.firstChild);
}
}
document.getElementById("showaddmembersform").disabled = false;
document.getElementById("showeditgroupsettingsform").disabled = false;
document.getElementById("deletegroup").disabled = false;
2007-01-22 06:06:08 +00:00
var sUrl = this.wwwRoot+"/group/index.php?id="+this.courseId+"&group="+groupId+"&act_ajax_getmembersingroup";
YAHOO.util.Connect.asyncRequest("GET", sUrl, this.connectCallback, null);
2007-01-22 06:06:08 +00:00
};
2007-01-22 06:06:08 +00:00
var createLoaderImg = function (elClass, parentId, wwwRoot) {
var parentEl = document.getElementById(parentId);
if (!parentEl) {
return false;
}
2007-01-23 06:20:47 +00:00
if (document.getElementById("loaderImg")) {
// A loader image already exists.
2007-01-22 06:06:08 +00:00
return false;
}
var loadingImg = document.createElement("img");
loadingImg.setAttribute("src", wwwRoot+"/pix/i/ajaxloader.gif");
2007-01-22 06:06:08 +00:00
loadingImg.setAttribute("class", elClass);
loadingImg.setAttribute("alt", "Loading");
2007-01-23 06:20:47 +00:00
loadingImg.setAttribute("id", "loaderImg");
2007-01-22 06:06:08 +00:00
parentEl.appendChild(loadingImg);
return true;
};
2007-01-22 06:06:08 +00:00
var removeLoaderImgs = function (elClass, parentId) {
var parentEl = document.getElementById(parentId);
if (parentEl) {
2007-01-23 06:20:47 +00:00
var loader = document.getElementById("loaderImg");
parentEl.removeChild(loader);
2007-01-22 06:06:08 +00:00
}
};