forked from extern/egroupware
Make calendar entry resizable
This commit is contained in:
parent
2f083e41e4
commit
a014b7ba7c
@ -34,9 +34,10 @@ class calendar_ajax {
|
|||||||
* @param string $calendarOwner the owner of the calendar the event is in
|
* @param string $calendarOwner the owner of the calendar the event is in
|
||||||
* @param string $targetDateTime the datetime where the event should be moved to, format: YYYYMMDD
|
* @param string $targetDateTime the datetime where the event should be moved to, format: YYYYMMDD
|
||||||
* @param string $targetOwner the owner of the target calendar
|
* @param string $targetOwner the owner of the target calendar
|
||||||
|
* @param string $durationT the duration to support resizable calendar event
|
||||||
* @return string XML response if no error occurs
|
* @return string XML response if no error occurs
|
||||||
*/
|
*/
|
||||||
function moveEvent($eventId,$calendarOwner,$targetDateTime,$targetOwner)
|
function moveEvent($eventId,$calendarOwner,$targetDateTime,$targetOwner,$durationT=null)
|
||||||
{
|
{
|
||||||
// we do not allow dragging into another users calendar ATM
|
// we do not allow dragging into another users calendar ATM
|
||||||
if(!$calendarOwner == $targetOwner)
|
if(!$calendarOwner == $targetOwner)
|
||||||
@ -45,7 +46,14 @@ class calendar_ajax {
|
|||||||
}
|
}
|
||||||
|
|
||||||
$old_event=$event=$this->calendar->read($eventId);
|
$old_event=$event=$this->calendar->read($eventId);
|
||||||
$duration=$event['end']-$event['start'];
|
if (!$durationT)
|
||||||
|
{
|
||||||
|
$duration=$event['end']-$event['start'];
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
$duration = $durationT;
|
||||||
|
}
|
||||||
|
|
||||||
$event['start'] = $this->calendar->date2ts($targetDateTime);
|
$event['start'] = $this->calendar->date2ts($targetDateTime);
|
||||||
$event['end'] = $event['start']+$duration;
|
$event['end'] = $event['start']+$duration;
|
||||||
|
@ -1864,8 +1864,8 @@ class calendar_uiviews extends calendar_ui
|
|||||||
.'onmousemove="event.cancelBubble=true;"';
|
.'onmousemove="event.cancelBubble=true;"';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
$resizableHelper = $this->bo->date2string($event['start']). '|' .$this->bo->format_date($event['start'],false) . '|' . $this->cal_prefs['interval'];
|
||||||
$html = $indent.'<div id="'.$draggableID.'" class="calendar_calEvent'.($is_private ? 'Private' : '').' '.$status_class.
|
$html = $indent.'<div id="'.$draggableID.'" data-resize="'.$resizableHelper.' " class="calendar_calEvent'.($is_private ? 'Private' : '').' '.$status_class.
|
||||||
'" style="'.$style.' border-color: '.$headerbgcolor.'; background: '.$background.'; z-index: '.$z_index.';"'.
|
'" style="'.$style.' border-color: '.$headerbgcolor.'; background: '.$background.'; z-index: '.$z_index.';"'.
|
||||||
$popup.' '.html::tooltip($tooltip,False,$ttip_options).
|
$popup.' '.html::tooltip($tooltip,False,$ttip_options).
|
||||||
$dd_emulation.'>'.$prefix_icon."\n".$ie_fix.$html."\n".
|
$dd_emulation.'>'.$prefix_icon."\n".$ie_fix.$html."\n".
|
||||||
|
@ -137,7 +137,23 @@ app.classes.calendar = AppJS.extend(
|
|||||||
event.helper.width(jQuery("#calColumn").width());
|
event.helper.width(jQuery("#calColumn").width());
|
||||||
},
|
},
|
||||||
|
|
||||||
});
|
}).resizable({
|
||||||
|
handles: "s",
|
||||||
|
start:function(ui,event){
|
||||||
|
|
||||||
|
},
|
||||||
|
stop:function(ui,event){
|
||||||
|
var resizeHelper = ui.target.getAttribute('data-resize');
|
||||||
|
var dataResize = resizeHelper.split("|");
|
||||||
|
var time = dataResize[1].split(":");
|
||||||
|
var dropDate = dataResize[0]+"T"+time[0]+time[1];
|
||||||
|
|
||||||
|
var drop = jQuery("div[id^='drop_"+dropDate+"']");
|
||||||
|
var newDuration = Math.round(this.clientHeight/drop[0].clientHeight)* parseInt(dataResize[2]) * 60;
|
||||||
|
that.dropEvent(this.getAttribute('id'),dropDate,newDuration);
|
||||||
|
},
|
||||||
|
|
||||||
|
});;
|
||||||
|
|
||||||
|
|
||||||
//Droppable
|
//Droppable
|
||||||
@ -168,7 +184,7 @@ app.classes.calendar = AppJS.extend(
|
|||||||
if (dpOwner == null) dpOwner = dgOwner;
|
if (dpOwner == null) dpOwner = dgOwner;
|
||||||
if (dpOwner == dgOwner )
|
if (dpOwner == dgOwner )
|
||||||
{
|
{
|
||||||
that.dropEvent(event.draggable[0].id, id.target.getAttribute('id').substring(id.target.getAttribute('id').lastIndexOf("drop_")+5, id.target.getAttribute('id').lastIndexOf("_O")));
|
that.dropEvent(event.draggable[0].id, id.target.getAttribute('id').substring(id.target.getAttribute('id').lastIndexOf("drop_")+5, id.target.getAttribute('id').lastIndexOf("_O")),null);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -222,9 +238,10 @@ app.classes.calendar = AppJS.extend(
|
|||||||
*
|
*
|
||||||
* @param {string} _id dragged event id
|
* @param {string} _id dragged event id
|
||||||
* @param {array} _date array of date,hour, and minute of dropped cell
|
* @param {array} _date array of date,hour, and minute of dropped cell
|
||||||
|
* @param {string} _duration description
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
dropEvent : function(_id, _date)
|
dropEvent : function(_id, _date, _duration)
|
||||||
{
|
{
|
||||||
var eventId = _id.substring(_id.lastIndexOf("drag_")+5,_id.lastIndexOf("_O"));
|
var eventId = _id.substring(_id.lastIndexOf("drag_")+5,_id.lastIndexOf("_O"));
|
||||||
var calOwner = _id.substring(_id.lastIndexOf("_O")+2,_id.lastIndexOf("_C"));
|
var calOwner = _id.substring(_id.lastIndexOf("_O")+2,_id.lastIndexOf("_C"));
|
||||||
@ -235,7 +252,8 @@ app.classes.calendar = AppJS.extend(
|
|||||||
eventId,
|
eventId,
|
||||||
calOwner,
|
calOwner,
|
||||||
date,
|
date,
|
||||||
eventOwner
|
eventOwner,
|
||||||
|
_duration
|
||||||
);
|
);
|
||||||
},
|
},
|
||||||
/**
|
/**
|
||||||
|
Loading…
Reference in New Issue
Block a user