mirror of
https://github.com/EGroupware/egroupware.git
synced 2025-01-03 04:29:28 +01:00
Calendar: More work on drag vs jiggle click
Now user must drag into the next time block to start drag to create. Any movement inside the same time block is treated as a click.
This commit is contained in:
parent
16c9f5ef1d
commit
0e011c63e7
@ -1040,6 +1040,7 @@ export class et2_calendar_event extends et2_valueWidget implements et2_IDetached
|
||||
|
||||
result = this.onclick.apply(this, args);
|
||||
}
|
||||
_ev.stopImmediatePropagation();
|
||||
return result;
|
||||
}
|
||||
|
||||
|
@ -1971,7 +1971,7 @@ export class et2_calendar_timegrid extends et2_calendar_view implements et2_IDet
|
||||
if(_ev.target.dataset.id || jQuery(_ev.target).parents('.calendar_calEvent').length)
|
||||
{
|
||||
// Event came from inside, maybe a calendar event
|
||||
var event = this._get_event_info(_ev.originalEvent.target);
|
||||
var event = this._get_event_info(_ev.target.closest(".calendar_calEvent"));
|
||||
if(typeof this.onclick == 'function')
|
||||
{
|
||||
// Make sure function gets a reference to the widget, splice it in as 2. argument if not
|
||||
@ -2122,12 +2122,8 @@ export class et2_calendar_timegrid extends et2_calendar_view implements et2_IDet
|
||||
// Start update
|
||||
var timegrid = this;
|
||||
this.div.on('mousemove.dragcreate', function()
|
||||
{
|
||||
if(timegrid.drag_create.event && timegrid.drag_create.parent && timegrid.drag_create.end)
|
||||
{
|
||||
var end = jQuery.extend({}, timegrid.gridHover[0].dataset);
|
||||
if(end.date)
|
||||
{
|
||||
let date = timegrid.date_helper(end.date);
|
||||
if(end.hour)
|
||||
{
|
||||
@ -2137,8 +2133,22 @@ export class et2_calendar_timegrid extends et2_calendar_view implements et2_IDet
|
||||
{
|
||||
date.setUTCMinutes(end.minute);
|
||||
}
|
||||
timegrid.drag_create.end.date = date;
|
||||
if(!timegrid.drag_create.event && date.toJSON() != start.date.toJSON())
|
||||
{
|
||||
timegrid._drag_create_start(start);
|
||||
// Create the event immediately
|
||||
timegrid._drag_create_event();
|
||||
}
|
||||
if(timegrid.drag_create.event && timegrid.drag_create.parent && timegrid.drag_create.end)
|
||||
{
|
||||
|
||||
timegrid.drag_create.end.date = date;
|
||||
if(timegrid.drag_create.start.date.toJSON() == timegrid.drag_create.end.date.toJSON())
|
||||
{
|
||||
// Minimum drag size is time granularity or default
|
||||
timegrid.drag_create.end.date.setUTCMinutes(timegrid.drag_create.end.date.getUTCMinutes() + (timegrid.options.granularity || timegrid.egw().preference("defaultlength", "calendar")));
|
||||
}
|
||||
|
||||
try
|
||||
{
|
||||
timegrid._drag_update_event();
|
||||
@ -2150,7 +2160,6 @@ export class et2_calendar_timegrid extends et2_calendar_view implements et2_IDet
|
||||
}
|
||||
});
|
||||
}
|
||||
return this._drag_create_start(start);
|
||||
}
|
||||
|
||||
/**
|
||||
@ -2160,7 +2169,10 @@ export class et2_calendar_timegrid extends et2_calendar_view implements et2_IDet
|
||||
*/
|
||||
_mouse_up(event)
|
||||
{
|
||||
if (this.options.readonly) return;
|
||||
if(this.options.readonly)
|
||||
{
|
||||
return;
|
||||
}
|
||||
let end = {...this.gridHover[0].dataset};
|
||||
if(end.date)
|
||||
{
|
||||
@ -2178,7 +2190,20 @@ export class et2_calendar_timegrid extends et2_calendar_view implements et2_IDet
|
||||
this.div.off('mousemove.dragcreate');
|
||||
this.gridHover.css('cursor', '');
|
||||
|
||||
this._drag_create_end(this.drag_create.event ? {date: end.date} : undefined);
|
||||
if(this.drag_create.end)
|
||||
{
|
||||
this._drag_create_end(this.drag_create.end);
|
||||
}
|
||||
else
|
||||
{
|
||||
// Not dragged enough to count, but Firefox will still count it as a click
|
||||
if(navigator.userAgent.toLowerCase().indexOf('firefox') == -1)
|
||||
{
|
||||
// Fake a click for non-ff
|
||||
event.stopImmediatePropagation();
|
||||
this.gridHover[0].dispatchEvent(new Event("click"));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -524,7 +524,9 @@ export class et2_calendar_view extends et2_valueWidget
|
||||
{
|
||||
this.drag_create.start = null;
|
||||
}
|
||||
this.drag_create.end = start;
|
||||
this.drag_create.end = {...start, date: new Date(start.date.valueOf())};
|
||||
// Begin at default duration
|
||||
this.drag_create.end.date.setUTCMinutes(this.drag_create.end.date.getUTCMinutes() + (this.egw().preference("defaultlength", "calendar") ?? 60));
|
||||
|
||||
// Clear some stuff, if last time did not complete
|
||||
if(this.drag_create.event)
|
||||
@ -540,7 +542,7 @@ export class et2_calendar_view extends et2_valueWidget
|
||||
{
|
||||
// Create event
|
||||
this._drag_create_event()
|
||||
}, 500);
|
||||
}, 100);
|
||||
}
|
||||
|
||||
/**
|
||||
|
Loading…
Reference in New Issue
Block a user