Hi When using group view we need the reminders to be shown for a selected (set programitically) resource. At the moment it shows reminders for all resources that have appointments that need reminding. In our case we have users who have scheduler open in group view showing multiple resources but would only like to be reminded about appointments that are for the user using the system.
This request is to add Working hours range of the view, which will style the cells as working and non working. In addition, add a property ShowWorkingHours while will determine whether non-working hours are visible or not. Or perhaps for the sake of consistency, we can have API as in the day view: dayView.RangeFactor = ScaleRange.QuarterHour dayView.RulerStartScale = 9 dayView.RulerStartScaleMinutes = 30 dayView.RulerEndScale = 14 dayView.RulerEndScaleMinutes = 45
The recurrence rule has a missing letter "Z" at the end of the start/end values.
To reproduce: - Add mapping for the reminder property and try to save it in the database. Workaround: appointmentMappingInfo.Reminder = "Reminder"; appointmentMappingInfo.FindBySchedulerProperty("Reminder").ConvertToScheduler = ConvertReminderToScheduler; appointmentMappingInfo.FindBySchedulerProperty("Reminder").ConvertToDataSource = ConvertReminderToDataSource; private object ConvertReminderToDataSource(object item) private object ConvertReminderToDataSource(object item) { TimeSpan? reminder = item as TimeSpan?; if (reminder != null) { return (int)reminder.Value.TotalMilliseconds; } return 0; } private object ConvertReminderToScheduler(object item) { try { int value = Convert.ToInt32(item); if (value != 0) { return TimeSpan.FromMilliseconds(value); } return null; } catch { return null; } }
ADD. RadScheduler - add the ability to change the culture of the generated print document.
To reproduce: 1. Add several appointments: Random rand = new Random(); for (int i = 0; i < 5; i++) { Appointment app = new Appointment(DateTime.Now.AddHours(i), TimeSpan.FromMinutes(45), "App" + i); app.BackgroundId = this.radScheduler1.Backgrounds[rand.Next(0, radScheduler1.Backgrounds.Count)].Id; this.radScheduler1.Appointments.Add(app); } 2. On RadButton.Click event try to change the PrintStyle and print the scheduler: private void radButton1_Click(object sender, EventArgs e) { SchedulerDetailsPrintStyle detailsStyle = new SchedulerDetailsPrintStyle(); detailsStyle.PageBreakMode = PageBreakMode.Day; this.radScheduler1.PrintStyle = detailsStyle; this.radScheduler1.Print(); }
To reproduce: Add appointments to TimelineView so that they create a vertical scrollbar. Scroll to bottom and click at the last appointment, you will see that the scrollbar will return back to the start and will hide for a moment Workaround: Use the following custom scheduler: public class Myscheduler : RadScheduler { public override string ThemeClassName { get { return typeof(RadScheduler).FullName; } set { base.ThemeClassName = value; } } protected override RadSchedulerElement CreateRadSchedulerElement() { return new MySchedulerElement(this, this.ActiveView); } } class MySchedulerElement : RadSchedulerElement { public MySchedulerElement(RadScheduler scheduler, SchedulerView view) : base(scheduler, view) { } protected override SchedulerViewElement CreateViewElement() { if (this.Scheduler.ActiveViewType == SchedulerViewType.Timeline && this.Scheduler.GroupType == GroupType.None) { return new MyTimelineViewElement(this.Scheduler, this.View); } return base.CreateViewElement(); } } class MyTimelineViewElement : SchedulerTimelineViewElement { public MyTimelineViewElement(RadScheduler scheduler, SchedulerView view) : base(scheduler, view) { } protected override void UpdateVeticalScroll(float presenterHeight, float appointmentsMaxHeight) { base.UpdateVeticalScroll(presenterHeight, appointmentsMaxHeight + this.VScrollBar.Value); } }
Please refer to the attached file.
If your current time is 9:30 AM and you have an appointment in 11:00 AM with reminder 6 hours, the alarm popup should be displayed at 5:00 AM. When you run the application and show the scheduler, the reminder pop up appears immediately. This behavior is expected. However, if you snooze the event with 1 hour, it is expected that the reminder for this appointment will not popup the next hour. However, the RadScheduler makes the following calculation: reminder start time - reminder value + snooze time = 11:00 - 6 + 1 = 6:00. Hence, the reminder popup shows immediately as the current time is 9:30h.
To reproduce: 1. Open Demo application >> Scheduler >> Printing example. 2. Change to Weekly style and return back to Daily style. 3. Modify a random appointment's end time to be half an hour, e.g. 10:30. 4. Change the rule scale to 5 minute and press PrintPreview button. You will notice that the rendered appointment in the PrintPreview dialog fills the entire hour interval, instead of half of it. public Form1() { InitializeComponent(); this.radScheduler1.PrintStyle = new CustomSchedulerDailyPrintStyle(); } public class CustomSchedulerDailyPrintStyle :SchedulerDailyPrintStyle { protected override void DrawAppointments(DateTime currentDate, IResource resource, Rectangle appArea, Graphics graphics) { int rowCount = Math.Max(1, (int)Math.Ceiling((TimeEndRange - TimeSpan.FromHours(TimeStartRange.Hours)).TotalHours)); float rowHeight = (float)appArea.Height / rowCount; List<IEvent> appointments = this.GetAppointments(currentDate, false, resource); appointments.Sort(CompareAppointments); bool setColumn = true; Dictionary<IEvent, int> columns = new Dictionary<IEvent, int>(); Dictionary<IEvent, int> maxColumns = new Dictionary<IEvent, int>(); int currentColumn = 0; while (setColumn) { setColumn = false; DateTime currentTime = DateTime.MinValue; foreach (IEvent app in appointments) { if (!columns.ContainsKey(app) && DateFloor(app.Start) >= currentTime) { setColumn = true; columns.Add(app, currentColumn); currentTime = DateCeiling(app.End); } } currentColumn++; } DateTime maxEndDate = DateTime.MinValue; int lastIndex = 0; int maxColumn = 0; for (int i = 0; i <= appointments.Count; i++) { if (i == appointments.Count || DateFloor(appointments[i].Start) >= maxEndDate) { for (int j = lastIndex; j < i; j++) { maxColumns.Add(appointments[j], maxColumn); } maxColumn = 0; lastIndex = i; } if (i == appointments.Count) { break; } maxColumn = Math.Max(maxColumn, columns[appointments[i]]); if (maxEndDate < DateCeiling(appointments[i].End)) { maxEndDate = DateCeiling(appointments[i].End); } } foreach (IEvent app in appointments) { AppointmentPrintElement printedAppointment = new AppointmentPrintElement(app, this.Scheduler); printedAppointment.ShowHours = false; printedAppointment.DrawBorder = printedAppointment.DrawFill = true; float appY = appArea.Y + Math.Max(0, (float)(((DateFloor(printedAppointment.Start) - currentDate.Add(this.TimeStartRange)).TotalHours) * rowHeight)); float appBottom = appArea.Y + Math.Min(appArea.Height, (float)(((DateCeiling(printedAppointment.End) - currentDate.Add(this.TimeStartRange)).TotalHours) * rowHeight)); float appHeight = appBottom - appY - app.End.Minute; float appWidth = (appArea.Width - HoursColumnWidth) / (maxColumns[app] + 1); float appX = appArea.X + HoursColumnWidth + columns[app] * appWidth; RectangleF appRect = new RectangleF(appX, appY, appWidth, appHeight); appRect.Inflate(-2f, -2f); this.DrawAppointment(printedAppointment, graphics, appRect); } } } private void radButton1_Click(object sender, EventArgs e) { this.radScheduler1.PrintPreview(); }
Add Reminder property to the AppointmentMappingInfo class.
The tooltip is displayed in in wrong position when it contains several lines.
To reproduce: public Form1() { InitializeComponent(); this.radScheduler1.GetDayView().RangeFactor = Telerik.WinControls.UI.ScaleRange.HalfHour; this.radScheduler1.Appointments.Add(new Appointment(new DateTime(2014, 7, 21, 11, 0, 0, 0), new DateTime(2014, 7, 21, 12, 0, 0, 0))); this.radScheduler1.Appointments.Add(new Appointment(new DateTime(2014, 7, 21, 15, 30, 45, 137 ), new DateTime(2014, 7, 21, 15, 30, 58, 600 ))); this.radScheduler1.Appointments.Add(new Appointment(new DateTime(2014, 7, 21, 10, 0, 0, 0 ), new DateTime(2014, 7, 21, 11, 0, 0, 0 ))); this.radScheduler1.Appointments.Add(new Appointment(new DateTime(2014, 7, 21, 15, 30, 19, 633 ), new DateTime(2014, 7, 21, 15, 30, 31, 253 ))); this.radScheduler1.Appointments.Add(new Appointment(new DateTime(2014, 7, 21, 15, 29, 20, 337 ), new DateTime(2014, 7, 21, 15, 29, 52, 767 ))); this.radScheduler1.Appointments.Add(new Appointment(new DateTime(2014, 7, 21, 13, 0, 0, 0 ), new DateTime(2014, 7, 21, 14, 0, 0, 0 ))); this.radScheduler1.Appointments.Add(new Appointment(new DateTime(2014, 7, 21, 15, 0, 0, 0 ), new DateTime(2014, 7, 21, 16, 0, 0, 0 ))); this.radScheduler1.Appointments.Add(new Appointment(new DateTime(2014, 7, 21, 15, 28, 15, 500 ), new DateTime(2014, 7, 21, 15, 28, 37, 310 ))); this.radScheduler1.Appointments.Add(new Appointment(new DateTime(2014, 7, 21, 14, 0, 0, 0 ), new DateTime(2014, 7, 21, 15, 0, 0, 0 ))); this.radScheduler1.Appointments.Add(new Appointment(new DateTime(2014, 7, 21, 15, 27, 19, 123 ), new DateTime(2014, 7, 21, 15, 27, 57, 357 ))); }
Implement similar functionality as the exact time rendering in Outlook (DayView) using the status area. Please refer to the attached screenshot.
To reproduce : 1. Add a RadScheduler and a RadToggleButton. 2. Use the following code snippet: Private Sub Form1_Load(sender As Object, e As EventArgs) Handles MyBase.Load Me.RadScheduler1.ActiveViewType = Telerik.WinControls.UI.SchedulerViewType.Timeline Dim colors As Color() = New Color() {Color.LightBlue, Color.LightGreen, Color.LightYellow, Color.Red, Color.Orange, Color.Pink, _ Color.Purple, Color.Peru, Color.PowderBlue} Dim names As String() = New String() {"Alan Smith", "Anne Dodsworth", "Boyan Mastoni", "Richard Duncan", "Maria Shnaider"} For i As Integer = 0 To names.Length - 1 Dim resource As New Resource() resource.Id = New EventId(i) resource.Name = names(i) resource.Color = colors(i) Me.RadScheduler1.Resources.Add(resource) Next Me.RadScheduler1.ActiveView.ResourcesPerView = 2 Dim timelineView As SchedulerTimelineView = Me.RadScheduler1.GetTimelineView() Dim scale As Timescales = Timescales.Hours timelineView.ShowTimescale(scale) timelineView.StartDate = DateTime.Now.Date.AddHours(5) timelineView.RangeStartDate = DateTime.Now.Date.AddHours(5) timelineView.RangeEndDate = DateTime.Now.Date.AddHours(15) timelineView.CurrentScale.DisplayedCellsCount = 10 End Sub Private Sub RadToggleButton1_ToggleStateChanged(sender As Object, args As StateChangedEventArgs) Handles RadToggleButton1.ToggleStateChanged If args.ToggleState = Telerik.WinControls.Enumerations.ToggleState.On Then Me.RadScheduler1.GroupType = GroupType.Resource Else Me.RadScheduler1.GroupType = GroupType.None End If End Sub Initially, the timeline view start from the correct hour (5 AM). However, the horizontal scroll bar allows you to navigate in right direction as the RangeEndDate is currently visible in the view. When you click the toggle button, the scheduler is grouped by resources and the timeline start is reset.