Fix some update conditions that were missing some cases

This commit is contained in:
Nathan Gray 2015-11-13 20:22:58 +00:00
parent ddb63f4f46
commit 43e69977f2
4 changed files with 62 additions and 14 deletions

View File

@ -215,6 +215,13 @@ class calendar_uiforms extends calendar_ui
notifications::errors(true); notifications::errors(true);
$messages = null; $messages = null;
$msg_permission_denied_added = false; $msg_permission_denied_added = false;
// We'd like to just refresh the data as that's the fastest, but some changes
// affect more than just one event widget, so require a full refresh.
// $update_type is one of the update types
// (add, edit, update, delete)
$update_type = 'update';
list($button) = @each($content['button']); list($button) = @each($content['button']);
if (!$button && $content['action']) $button = $content['action']; // action selectbox if (!$button && $content['action']) $button = $content['action']; // action selectbox
unset($content['button']); unset($content['action']); unset($content['button']); unset($content['action']);
@ -247,6 +254,7 @@ class calendar_uiforms extends calendar_ui
unset($content['recur_exception'][$key]); unset($content['recur_exception'][$key]);
$content['recur_exception'] = array_values($content['recur_exception']); $content['recur_exception'] = array_values($content['recur_exception']);
} }
$update_type = 'edit';
} }
// delete an alarm // delete an alarm
if ($content['alarm']['delete_alarm']) if ($content['alarm']['delete_alarm'])
@ -691,6 +699,7 @@ class calendar_uiforms extends calendar_ui
unset($recur_event['start']); unset($recur_event['end']); // no update necessary unset($recur_event['start']); unset($recur_event['end']); // no update necessary
unset($recur_event['alarm']); // unsetting alarms too, as they cant be updated without start! unset($recur_event['alarm']); // unsetting alarms too, as they cant be updated without start!
$this->bo->update($recur_event,true); // no conflict check here $this->bo->update($recur_event,true); // no conflict check here
foreach($recur_event as $_k => $_v) error_log($_k . ': ' . array2string($_v));
unset($recur_event); unset($recur_event);
unset($event['edit_single']); // if we further edit it, it's just a single event unset($event['edit_single']); // if we further edit it, it's just a single event
unset($preserv['edit_single']); unset($preserv['edit_single']);
@ -701,6 +710,7 @@ class calendar_uiforms extends calendar_ui
$event['reference'] = $event['recurrence'] = 0; $event['reference'] = $event['recurrence'] = 0;
$event['uid'] = $content['uid']; $event['uid'] = $content['uid'];
} }
$update_type = 'edit';
} }
else // we edited a non-reccuring event or the whole series else // we edited a non-reccuring event or the whole series
{ {
@ -708,6 +718,8 @@ class calendar_uiforms extends calendar_ui
{ {
if ($event['recur_type'] != MCAL_RECUR_NONE) if ($event['recur_type'] != MCAL_RECUR_NONE)
{ {
$update_type = 'edit';
// we edit a existing series event // we edit a existing series event
if ($event['start'] != $old_event['start'] || if ($event['start'] != $old_event['start'] ||
$event['whole_day'] != $old_event['whole_day']) $event['whole_day'] != $old_event['whole_day'])
@ -851,6 +863,7 @@ class calendar_uiforms extends calendar_ui
// series moved by splitting in two --> move alarms and exceptions // series moved by splitting in two --> move alarms and exceptions
if ($old_event && $old_event['id'] != $event['id']) if ($old_event && $old_event['id'] != $event['id'])
{ {
$update_type = 'edit';
foreach ((array)$old_alarms as $alarm) foreach ((array)$old_alarms as $alarm)
{ {
// check if alarms still needed in old event, if not delete it // check if alarms still needed in old event, if not delete it
@ -919,7 +932,7 @@ class calendar_uiforms extends calendar_ui
} }
$response = egw_json_response::get(); $response = egw_json_response::get();
if($response) if($response && $update_type == 'update')
{ {
// Directly update stored data. If event is still visible, it will // Directly update stored data. If event is still visible, it will
// be notified & update itself. // be notified & update itself.
@ -935,7 +948,7 @@ class calendar_uiforms extends calendar_ui
} }
$msg = $message . ($msg ? ', ' . $msg : ''); $msg = $message . ($msg ? ', ' . $msg : '');
egw_framework::refresh_opener($msg, 'calendar', $event['id']); egw_framework::refresh_opener($msg, 'calendar', $event['id'], $event['recur_type'] ? 'edit' : $update_type);
// writing links for new entry, existing ones are handled by the widget itself // writing links for new entry, existing ones are handled by the widget itself
if (!$content['id'] && is_array($content['link_to']['to_id'])) if (!$content['id'] && is_array($content['link_to']['to_id']))
{ {
@ -2640,12 +2653,42 @@ class calendar_uiforms extends calendar_ui
$d->setUser(); $d->setUser();
} }
$event = $this->bo->read($eventId, $d, true); $event = $this->bo->read($eventId, $d, true);
$preserv['actual_date'] = $d; // remember the date clicked
// For DnD, always create an exception // For DnD, create an exception if they gave the date
$this->_create_exception($event,$preserv); $this->_create_exception($event,$preserv);
unset($event['id']); unset($event['id']);
$date = $d->format('ts'); $date = $d->format('ts');
$conflicts = $this->bo->update($event,false,true,false,true,$messages);
if (!is_array($conflicts) && $conflicts)
{
// now we need to add the original start as recur-execption to the series
$recur_event = $this->bo->read($event['reference']);
$recur_event['recur_exception'][] = $this->bo->date2ts($targetDateTime);
// check if we need to move the alarms, because they are next on that exception
foreach($recur_event['alarm'] as $id => $alarm)
{
if ($alarm['time'] == $content['edit_single'] - $alarm['offset'])
{
$rrule = calendar_rrule::event2rrule($recur_event, true);
foreach ($rrule as $time)
{
if ($content['edit_single'] < $time->format('ts'))
{
$alarm['time'] = $time->format('ts') - $alarm['offset'];
$this->bo->save_alarm($event['reference'], $alarm);
break;
}
}
}
}
unset($recur_event['start']); unset($recur_event['end']); // no update necessary
unset($recur_event['alarm']); // unsetting alarms too, as they cant be updated without start!
$this->bo->update($recur_event,true); // no conflict check here
unset($recur_event);
unset($event['edit_single']); // if we further edit it, it's just a single event
unset($preserv['edit_single']);
}
} }
// Drag a whole day to a time // Drag a whole day to a time
@ -2699,14 +2742,16 @@ class calendar_uiforms extends calendar_ui
$response = egw_json_response::get(); $response = egw_json_response::get();
if(!is_array($conflicts) && $conflicts) if(!is_array($conflicts) && $conflicts)
{ {
// Directly update stored data. If event is still visible, it will if(!$event['recur_type'] && !$old_event['recur_type'])
// be notified & update itself.
$this->to_client($event);
$response->call('egw.dataStoreUID','calendar::'.$event['id'].($date?':'.$date:''),$event);
if(!$sameday )
{ {
$response->call('egw.refresh', '','calendar',$event['id'],'update'); // Directly update stored data. If event is still visible, it will
// be notified & update itself.
$this->to_client($event);
$response->call('egw.dataStoreUID','calendar::'.$event['id'].($date?':'.$date:''),$event);
}
else
{
$response->call('egw.refresh', '','calendar',$event['id'],'edit');
} }
} }
else if ($conflicts) else if ($conflicts)

View File

@ -259,7 +259,7 @@ app.classes.calendar = AppJS.extend(
{ {
event = egw.dataGetUIDdata('calendar::'+_id); event = egw.dataGetUIDdata('calendar::'+_id);
} }
if(event && event.data && event.data.date) if(_type != 'edit' && event && event.data && event.data.date)
{ {
var new_cache_id = app.classes.calendar._daywise_cache_id(event.data.date,this.state.owner) var new_cache_id = app.classes.calendar._daywise_cache_id(event.data.date,this.state.owner)
var daywise = egw.dataGetUIDdata(new_cache_id); var daywise = egw.dataGetUIDdata(new_cache_id);

View File

@ -162,7 +162,9 @@ var et2_calendar_event = et2_valueWidget.extend([et2_IDetachedDOM],
egw.dataStoreUID(old_cache_id,old_daywise); egw.dataStoreUID(old_cache_id,old_daywise);
egw.dataStoreUID(new_cache_id,new_daywise); egw.dataStoreUID(new_cache_id,new_daywise);
this._parent.removeChild(this); // This should now cease to exist, as new events have been created
this.free();
return;
} }
// Copy to avoid changes, which may cause nm problems // Copy to avoid changes, which may cause nm problems

View File

@ -414,7 +414,8 @@ var et2_calendar_timegrid = et2_valueWidget.extend([et2_IDetachedDOM, et2_IResiz
{ {
// Need to refresh the event with original info to clean up // Need to refresh the event with original info to clean up
var app_id = event_widget.options.value.app_id ? event_widget.options.value.app_id : event_widget.options.value.id + (event_widget.options.value.recur_type ? ':'+event_widget.options.value.recur_date : ''); var app_id = event_widget.options.value.app_id ? event_widget.options.value.app_id : event_widget.options.value.id + (event_widget.options.value.recur_type ? ':'+event_widget.options.value.recur_date : '');
egw().dataStoreUID(app_id,event_dataGetUIDdata(app_id)); egw().dataStoreUID('calendar::'+app_id,egw.dataGetUIDdata('calendar::'+app_id).data);
loading.remove();
return; return;
} }
//Get infologID if in case if it's an integrated infolog event //Get infologID if in case if it's an integrated infolog event