AppointmentDragEventArgs.AdditionalAppointments Property
Provides access to the collection of the additional dragged appointments.
Namespace: DevExpress.XtraScheduler
Assembly: DevExpress.XtraScheduler.v18.1.Core.dll
Declaration
Property Value
Type | Description |
---|---|
AppointmentBaseCollection | An AppointmentBaseCollection containing appointments dragged along with the initial appointments. |
Remarks
Handle the SchedulerControl.AdditionalAppointmentsDrag event to populate the AdditionalAppointments collection with the appointments which should be dragged along with the appointments initially dragged by the end-user.
Example
Note
A complete sample project is available at https://github.com/DevExpress-Examples/how-to-add-an-appointment-to-the-dragged-appointment-in-a-drag-and-drop-operation-t445652
private void SchedulerControl_AppointmentDrag(object sender, AppointmentDragEventArgs e) {
// Find a special appointment among visible appointments.
AppointmentBaseCollection visbileApts = schedulerControl1.ActiveView.GetAppointments();
Appointment apt = visbileApts.Find(item => (item.Subject == "Finalize" && item.ResourceId.Equals(e.HitResource.Id)));
if (apt == null) {
e.AdditionalAppointments.Clear();
}
else {
if (e.SourceAppointment != apt) {
// If the dragged appointment overlaps with the special appointment,
// add the special appointment to the AdditionalAppointments collection
// to drag along with the initial appointment.
// The AdditionalAppointmentsDrag event will occur.
if (e.EditedAppointment.End > apt.Start)
e.AdditionalAppointments.Add(apt);
else
e.AdditionalAppointments.Clear();
}
}
}
private void SchedulerControl1_AdditionalAppointmentsDrag(object sender, AdditionalAppointmentsDragEventArgs e) {
if (e.AdditionalAppointmentInfos.Count <= 0)
return;
AppointmentDragInfo aptInfo = e.AdditionalAppointmentInfos[0];
// If the end of the main dragged appointment becomes greater than the start of the special appointment,
// set the start of the special appointment being dragged to the end of the main dragged appointment.
// It prevents overlapping appointments.
if (e.PrimaryAppointmentInfos[0].EditedAppointment.End > aptInfo.SourceAppointment.Start)
aptInfo.EditedAppointment.Start = e.PrimaryAppointmentInfos[0].EditedAppointment.End;
}
Related GitHub Examples
The following code snippet (auto-collected from DevExpress Examples) contains a reference to the AdditionalAppointments property.
Note
The algorithm used to collect these code examples remains a work in progress. Accordingly, the links and snippets below may produce inaccurate results. If you encounter an issue with code examples below, please use the feedback form on this page to report the issue.