AutorÃa | Ultima modificación | Ver Log |
/*** Resource drag and drop.** @class M.course.dragdrop.resource* @constructor* @extends M.core.dragdrop*/var DRAGRESOURCE = function() {DRAGRESOURCE.superclass.constructor.apply(this, arguments);};Y.extend(DRAGRESOURCE, M.core.dragdrop, {initializer: function() {// Set group for parent classthis.groups = ['resource'];this.samenodeclass = CSS.ACTIVITY;this.parentnodeclass = CSS.SECTION;this.samenodelabel = {identifier: 'dragtoafter',component: 'quiz'};this.parentnodelabel = {identifier: 'dragtostart',component: 'quiz'};// Go through all sectionsthis.setup_for_section();// Initialise drag & drop for all resources/activitiesvar nodeselector = 'li.' + CSS.ACTIVITY;var del = new Y.DD.Delegate({container: '.' + CSS.COURSECONTENT,nodes: nodeselector,target: true,handles: ['.' + CSS.EDITINGMOVE],dragConfig: {groups: this.groups}});del.dd.plug(Y.Plugin.DDProxy, {// Don't move the node at the end of the dragmoveOnEnd: false,cloneNode: true});del.dd.plug(Y.Plugin.DDConstrained, {// Keep it inside the .mod-quiz-edit-contentconstrain: '#' + CSS.SLOTS});del.dd.plug(Y.Plugin.DDWinScroll);M.mod_quiz.quizbase.register_module(this);M.mod_quiz.dragres = this;},/*** Apply dragdrop features to the specified selector or node that refers to section(s)** @method setup_for_section* @param {String} baseselector The CSS selector or node to limit scope to*/setup_for_section: function() {Y.Node.all('.mod-quiz-edit-content ul.slots ul.section').each(function(resources) {resources.setAttribute('data-draggroups', this.groups.join(' '));// Define empty ul as droptarget, so that item could be moved to empty listnew Y.DD.Drop({node: resources,groups: this.groups,padding: '20 0 20 0'});// Initialise each resource/activity in this sectionthis.setup_for_resource('li.activity');}, this);},/*** Apply dragdrop features to the specified selector or node that refers to resource(s)** @method setup_for_resource* @param {String} baseselector The CSS selector or node to limit scope to*/setup_for_resource: function(baseselector) {Y.Node.all(baseselector).each(function(resourcesnode) {// Replace move iconsvar move = resourcesnode.one('a.' + CSS.EDITINGMOVE);if (move) {var resourcedraghandle = this.get_drag_handle(M.util.get_string('move', 'moodle'),CSS.EDITINGMOVE, CSS.ICONCLASS, true);move.replace(resourcedraghandle);}}, this);},drag_start: function(e) {// Get our drag objectvar drag = e.target;drag.get('dragNode').setContent(drag.get('node').get('innerHTML'));drag.get('dragNode').all('.icon').setStyle('vertical-align', 'baseline');},drag_dropmiss: function(e) {// Missed the target, but we assume the user intended to drop it// on the last ghost node location, e.drag and e.drop should be// prepared by global_drag_dropmiss parent so simulate drop_hit(e).this.drop_hit(e);},drop_hit: function(e) {var drag = e.drag;// Get a reference to our drag nodevar dragnode = drag.get('node');// Add spinner if it not therevar actionarea = dragnode.one(CSS.ACTIONAREA);var spinner = M.util.add_spinner(Y, actionarea);var params = {};// Handle any variables which we must pass back through tovar pageparams = this.get('config').pageparams;var varname;for (varname in pageparams) {params[varname] = pageparams[varname];}// Prepare request parametersparams.sesskey = M.cfg.sesskey;params.courseid = this.get('courseid');params.quizid = this.get('quizid');params['class'] = 'resource';params.field = 'move';params.id = Number(Y.Moodle.mod_quiz.util.slot.getId(dragnode));params.sectionId = Y.Moodle.core_course.util.section.getId(dragnode.ancestor('li.section', true));var previousslot = dragnode.previous(SELECTOR.SLOT);if (previousslot) {params.previousid = Number(Y.Moodle.mod_quiz.util.slot.getId(previousslot));}var previouspage = dragnode.previous(SELECTOR.PAGE);if (previouspage) {params.page = Number(Y.Moodle.mod_quiz.util.page.getId(previouspage));}// Do AJAX requestvar uri = M.cfg.wwwroot + this.get('ajaxurl');Y.io(uri, {method: 'POST',data: params,on: {start: function() {this.lock_drag_handle(drag, CSS.EDITINGMOVE);spinner.show();},success: function(tid, response) {var responsetext = Y.JSON.parse(response.responseText);var params = {element: dragnode, visible: responsetext.visible};M.mod_quiz.quizbase.invoke_function('set_visibility_resource_ui', params);this.unlock_drag_handle(drag, CSS.EDITINGMOVE);window.setTimeout(function() {spinner.hide();}, 250);M.mod_quiz.resource_toolbox.reorganise_edit_page();},failure: function(tid, response) {this.ajax_failure(response);this.unlock_drag_handle(drag, CSS.SECTIONHANDLE);spinner.hide();window.location.reload(true);}},context: this});},global_drop_over: function(e) {// Overriding parent method so we can stop the slots being dragged before the first page node.// Check that drop object belong to correct group.if (!e.drop || !e.drop.inGroup(this.groups)) {return;}// Get a reference to our drag and drop nodes.var drag = e.drag.get('node'),drop = e.drop.get('node');// Save last drop target for the case of missed target processing.this.lastdroptarget = e.drop;// Are we dropping within the same parent node?if (drop.hasClass(this.samenodeclass)) {var where;if (this.goingup) {where = "before";} else {where = "after";}drop.insert(drag, where);} else if ((drop.hasClass(this.parentnodeclass) || drop.test('[data-droptarget="1"]')) && !drop.contains(drag)) {// We are dropping on parent node and it is emptyif (this.goingup) {drop.append(drag);} else {drop.prepend(drag);}}this.drop_over(e);}}, {NAME: 'mod_quiz-dragdrop-resource',ATTRS: {courseid: {value: null},quizid: {value: null},ajaxurl: {value: 0},config: {value: 0}}});M.mod_quiz = M.mod_quiz || {};M.mod_quiz.init_resource_dragdrop = function(params) {new DRAGRESOURCE(params);};