100 lines
2.5 KiB
JavaScript
100 lines
2.5 KiB
JavaScript
(function(){
|
|
|
|
var temp_section,temp_time;
|
|
var before;
|
|
|
|
scheduler.config.collision_limit = 1;
|
|
scheduler.attachEvent("onBeforeDrag",function(id){
|
|
var pr = scheduler._props?scheduler._props[this._mode]:null;
|
|
var matrix = scheduler.matrix?scheduler.matrix[this._mode]:null;
|
|
var checked_mode = pr||matrix;
|
|
if(pr)
|
|
var map_to = checked_mode.map_to;
|
|
if(matrix)
|
|
var map_to = checked_mode.y_property;
|
|
|
|
if ((checked_mode) && id){
|
|
temp_section = this.getEvent(id)[map_to];
|
|
temp_time = this.getEvent(id).start_date;
|
|
}
|
|
return true;
|
|
});
|
|
scheduler.attachEvent("onBeforeLightbox",function(id){
|
|
var ev = scheduler.getEvent(id);
|
|
before = [ev.start_date, ev.end_date];
|
|
return true;
|
|
});
|
|
scheduler.attachEvent("onEventChanged",function(id){
|
|
if (!id) return true;
|
|
var ev = scheduler.getEvent(id);
|
|
if (!collision_check(ev)){
|
|
if (!before) return false;
|
|
ev.start_date = before[0];
|
|
ev.end_date = before[1];
|
|
ev._timed=this.is_one_day_event(ev);
|
|
};
|
|
return true;
|
|
});
|
|
scheduler.attachEvent("onBeforeEventChanged",function(ev,e,is_new){
|
|
return collision_check(ev);
|
|
});
|
|
scheduler.attachEvent("onEventSave",function(id, edited_ev){
|
|
//var ev = scheduler.getEvent(id);
|
|
if(edited_ev.rec_type)
|
|
scheduler._roll_back_dates(edited_ev);
|
|
|
|
return collision_check(edited_ev);
|
|
});
|
|
|
|
|
|
function collision_check(ev){
|
|
var evs = [];
|
|
|
|
if (ev.rec_type) {
|
|
var evs_dates = scheduler.getRecDates(ev);
|
|
for(var k=0; k<evs_dates.length; k++) {
|
|
var tevs = scheduler.getEvents(evs_dates[k].start_date, evs_dates[k].end_date);
|
|
for(var j=0; j<tevs.length; j++) {
|
|
if ((tevs[j].event_pid || tevs[j].id) != ev.id )
|
|
evs.push(tevs[j]);
|
|
}
|
|
}
|
|
evs.push(ev);
|
|
} else {
|
|
evs = scheduler.getEvents(ev.start_date, ev.end_date);
|
|
}
|
|
|
|
var pr = scheduler._props?scheduler._props[scheduler._mode]:null;
|
|
var matrix = scheduler.matrix?scheduler.matrix[scheduler._mode]:null;
|
|
|
|
var checked_mode = pr||matrix;
|
|
if(pr)
|
|
var map_to = checked_mode.map_to;
|
|
if(matrix)
|
|
var map_to = checked_mode.y_property;
|
|
|
|
var single = true;
|
|
if (checked_mode) {
|
|
var count = 0;
|
|
|
|
for (var i = 0; i < evs.length; i++)
|
|
if (evs[i][map_to] == ev[map_to])
|
|
count++;
|
|
|
|
if (count > scheduler.config.collision_limit) {
|
|
scheduler._drag_event.start_date = temp_time;
|
|
ev[map_to] = temp_section;
|
|
single = false;
|
|
}
|
|
}
|
|
else {
|
|
if (evs.length > scheduler.config.collision_limit)
|
|
single = false;
|
|
}
|
|
|
|
if (!single) return !scheduler.callEvent("onEventCollision",[ev,evs]);
|
|
return single;
|
|
|
|
};
|
|
|
|
})(); |