2 * To change this template, choose Tools | Templates
3 * and open the template in the editor.
9 M.core_group.init_hover_events = function(Y, events) {
10 // Prepare the overlay if it hasn't already been created
11 this.hoveroverlay = this.hoveroverlay || (function(){
13 var overlay = new Y.Overlay({
14 bodyContent : 'Loading',
18 // Render it against the page
19 overlay.render(Y.one('#page'));
23 Y.all('.group_hoverdescription').each(function() {
24 var node = this.ancestor();
25 var id = this.getAttribute('data-groupid');
27 node.on('mouseenter', function(){
28 M.core_group.hoveroverlay.set('xy', [this.getX()+(this.get('offsetWidth')/2),this.getY()+this.get('offsetHeight')-5]);
29 M.core_group.hoveroverlay.set("bodyContent", events[id]);
30 M.core_group.hoveroverlay.show();
31 M.core_group.hoveroverlay.get('boundingBox').setStyle('visibility', 'visible');
33 node.on('mouseleave', function(){
34 M.core_group.hoveroverlay.hide();
35 M.core_group.hoveroverlay.get('boundingBox').setStyle('visibility', 'hidden');
40 M.core_group.init_index = function(Y, wwwroot, courseid) {
41 M.core_group.groupsCombo = new UpdatableGroupsCombo(wwwroot, courseid);
42 M.core_group.membersCombo = new UpdatableMembersCombo(wwwroot, courseid);
45 M.core_group.groupslist = function(Y, preventgroupremoval) {
48 // We need to add check_deletable both on change for the groups, and then call it the first time the page loads
49 Y.one('#groups').on('change', this.check_deletable, this);
50 this.check_deletable();
52 check_deletable : function() {
53 // Ensure that if the 'preventremoval' attribute is set, the delete button is greyed out
55 var optionselected = false;
56 Y.one('#groups').get('options').each(function(option) {
57 if (option.get('selected')) {
58 optionselected = true;
59 if (option.getAttribute('value') in preventgroupremoval) {
64 var deletebutton = Y.one('#deletegroup');
65 if (candelete && optionselected) {
66 deletebutton.removeAttribute('disabled');
68 deletebutton.setAttribute('disabled', 'disabled');