diff --git a/src/addons/dragAndDrop/EventContainerWrapper.js b/src/addons/dragAndDrop/EventContainerWrapper.js index 583da4077..20df6ed27 100644 --- a/src/addons/dragAndDrop/EventContainerWrapper.js +++ b/src/addons/dragAndDrop/EventContainerWrapper.js @@ -118,9 +118,11 @@ class EventContainerWrapper extends React.Component { boundaryBox ) + const end = this._calculateDragEnd(start) + this.context.draggable.onDropFromOutside({ start, - end: slotMetrics.nextSlot(start), + end, allDay: false, resource, }) @@ -133,11 +135,25 @@ class EventContainerWrapper extends React.Component { { y: point.y, x: point.x }, bounds ) - const end = slotMetrics.nextSlot(start) + const end = this._calculateDragEnd(start) const event = this.context.draggable.dragFromOutsideItem() this.update(event, slotMetrics.getRange(start, end, false, true)) } + _calculateDragEnd = (start) => { + const { accessors, slotMetrics, localizer } = this.props + const event = this.context.draggable.dragFromOutsideItem() + const { duration: eventDuration } = eventTimes(event, accessors, localizer) + + const end = slotMetrics.nextSlot(start) + const eventHasDuration = !isNaN(eventDuration) + if (eventHasDuration) { + const eventEndSlot = localizer.add(start, eventDuration, 'milliseconds') + end = new Date(Math.max(eventEndSlot, end)) + } + return end + } + updateParentScroll = (parent, node) => { setTimeout(() => { const draggedEl = qsa(node, '.rbc-addons-dnd-drag-preview')[0] @@ -152,8 +168,8 @@ class EventContainerWrapper extends React.Component { parent, Math.min( draggedEl.offsetTop - - parent.offsetHeight + - draggedEl.offsetHeight, + parent.offsetHeight + + draggedEl.offsetHeight, parent.scrollHeight ) )