mirror of
https://github.com/EGroupware/egroupware.git
synced 2025-01-28 00:39:19 +01:00
Calendar: Fix full day non blocking events could not be dragged
This commit is contained in:
parent
a8a5a14b12
commit
2b61bf0303
@ -665,10 +665,10 @@ class calendar_ui
|
|||||||
$this->cal_prefs['saved_states']['cat_id']))
|
$this->cal_prefs['saved_states']['cat_id']))
|
||||||
{
|
{
|
||||||
$filter_check = array(
|
$filter_check = array(
|
||||||
'start' => $event['start'],
|
'start' => $event['start'] - 1,
|
||||||
'users' => $this->cal_prefs['saved_states']['owner'],
|
'users' => $this->cal_prefs['saved_states']['owner'],
|
||||||
'cat_id' => $this->cal_prefs['saved_states']['cat_id'],
|
'cat_id' => $this->cal_prefs['saved_states']['cat_id'],
|
||||||
'filter' => $this->cal_prefs['saved_states']['status_filter'],
|
'filter' => $this->cal_prefs['saved_states']['status_filter'],
|
||||||
'num_rows' => 1
|
'num_rows' => 1
|
||||||
);
|
);
|
||||||
$filter_match = (bool)$this->bo->search($filter_check, $this->bo->so->cal_table.".cal_id = {$event['id']}");
|
$filter_match = (bool)$this->bo->search($filter_check, $this->bo->so->cal_table.".cal_id = {$event['id']}");
|
||||||
|
@ -964,28 +964,30 @@ export class CalendarApp extends EgwApp
|
|||||||
|
|
||||||
let sortablejs = Sortable.create(sortable, {
|
let sortablejs = Sortable.create(sortable, {
|
||||||
ghostClass: 'srotable_cal_wk_ph',
|
ghostClass: 'srotable_cal_wk_ph',
|
||||||
draggable: state.view == 'day'? '.calendar_calDayColHeader' : '.view_row',
|
draggable: state.view == 'day' ? '.calendar_calDayColHeader' : '.view_row',
|
||||||
handle: state.view == 'day'? '.calendar_calToday' : '.calendar_calGridHeader',
|
handle: state.view == 'day' ? '.calendar_calToday' : '.calendar_calGridHeader',
|
||||||
animation: 100,
|
animation: 100,
|
||||||
filter: state.view == 'day'? '.calendar_calTimeGridScroll' : '.calendar_calDayColHeader',
|
filter: state.view == 'day' ? '.calendar_calTimeGridScroll' : '.calendar_calDayColHeader',
|
||||||
|
preventOnFilter: false, // Required for dnd fullday nonblocking
|
||||||
dataIdAttr: 'data-owner',
|
dataIdAttr: 'data-owner',
|
||||||
direction: state.view == 'day'? 'horizental' : 'vertical',
|
direction: state.view == 'day' ? 'horizental' : 'vertical',
|
||||||
sort: state.owner.length > 1 && (
|
sort: state.owner.length > 1 && (
|
||||||
state.view == 'day' && state.owner.length < parseInt(''+egw.preference('day_consolidate','calendar')) ||
|
state.view == 'day' && state.owner.length < parseInt('' + egw.preference('day_consolidate', 'calendar')) ||
|
||||||
(state.view == 'week' || state.view == 'day4') && state.owner.length < parseInt(''+egw.preference('week_consolidate','calendar'))), // enable/disable sort
|
(state.view == 'week' || state.view == 'day4') && state.owner.length < parseInt('' + egw.preference('week_consolidate', 'calendar'))), // enable/disable sort
|
||||||
onStart: function (event)
|
onStart: function(event)
|
||||||
{
|
{
|
||||||
// Put owners into row IDs
|
// Put owners into row IDs
|
||||||
CalendarApp.views[app.calendar.state.view].etemplates[0].widgetContainer.iterateOver(function(widget) {
|
CalendarApp.views[app.calendar.state.view].etemplates[0].widgetContainer.iterateOver(function(widget)
|
||||||
|
{
|
||||||
if(widget.options.owner && !widget.disabled)
|
if(widget.options.owner && !widget.disabled)
|
||||||
{
|
{
|
||||||
widget.div.parents('tr').attr('data-owner',widget.options.owner);
|
widget.div.parents('tr').attr('data-owner', widget.options.owner);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
widget.div.parents('tr').removeAttr('data-owner');
|
widget.div.parents('tr').removeAttr('data-owner');
|
||||||
}
|
}
|
||||||
},this,et2_calendar_timegrid);
|
}, this, et2_calendar_timegrid);
|
||||||
},
|
},
|
||||||
onSort: function(event)
|
onSort: function(event)
|
||||||
{
|
{
|
||||||
|
@ -243,8 +243,8 @@ export class et2_calendar_timegrid extends et2_calendar_view implements et2_IDet
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Load the event
|
// Load the event
|
||||||
timegrid._get_event_info(this);
|
const event_info = timegrid._get_event_info(this);
|
||||||
if(this.classList.contains("resizing"))
|
if(this.classList.contains("resizing") || event_info.whole_day === "true")
|
||||||
{
|
{
|
||||||
// Currently already resizing
|
// Currently already resizing
|
||||||
return;
|
return;
|
||||||
|
Loading…
Reference in New Issue
Block a user