Issue: Unable to set recurrence pattern of an appointment or a meeting as every weekday using Outlook Object Model
The only available recurrence patterns to set from OOM are as below:
olRecursDaily = 0,
olRecursWeekly = 1,
olRecursMonthly = 2,
olRecursMonthNth = 3,
olRecursYearly = 5,
and olRecursYearNth = 6.
Though we can set every weekday recurrence pattern using UI, Outlook object model does not expose any method to create the pattern as Every Weekday.
So, We could use "DayOfWeekMask" to workaround the issue; We found that the mask value is set to 62 on item when we set the recurrence pattern as Every Weekday through Outlook UI [Daily] -> [Every weekday].
Here is the sample code snippet in VBA and C# to workaround the issue:
NOTE: Following programming examples is for illustration only, without warranty either expressed or implied,
including, but not limited to, the implied warranties of merchantability and/or fitness for a particular purpose.
This sample code assumes that you are familiar with the programming language being demonstrated and the tools used
to create and debug procedures.
SAMPLE CODE I (VBA):
1: Sub CreateTestAppointment()
2: Dim myOlApp As Outlook.Application
3: Dim myItem As Outlook.AppointmentItem
4: Dim myPattern As Outlook.RecurrencePattern
5: Set myOlApp = CreateObject("Outlook.Application")
6: Set myItem = myOlApp.CreateItem(olAppointmentItem)
7: Set myPattern = myItem.GetRecurrencePattern
8: myPattern.RecurrenceType = 1
9: myPattern.DayOfWeekMask = 62
10: myPattern.StartTime = "12:00 pm" 'Time each appointment begins
11: myPattern.EndTime = "1:00 pm" 'Time each appointment ends
12: myPattern.PatternStartDate = #7/1/2009# 'Earliest date appt can Occur
13: myPattern.PatternEndDate = #9/2/2009# 'Latest date appt can occur
14:
15: myItem.Subject = "TestAppointment"
16: myItem.Save
17: myItem.Display
18: End Sub
SAMPLE CODE II (C#):
1: try
2: {
3: Outlook.Application oApp =(Outlook.Application) new Outlook.Application();
4: Outlook.AppointmentItem newAppointment =(Outlook.AppointmentItem) oApp.CreateItem(Outlook.OlItemType.olAppointmentItem);
5: Outlook.RecurrencePattern oRecurr = newAppointment.GetRecurrencePattern() ;
6:
7: oRecurr.RecurrenceType = Outlook.OlRecurrenceType.olRecursWeekly;
8: oRecurr.DayOfWeekMask = (Outlook.OlDaysOfWeek)62;
9: oRecurr.StartTime = DateTime.Now.AddHours(2);
10: oRecurr.EndTime = DateTime.Now.AddHours(3);
11: oRecurr.PatternStartDate = DateTime.Now.Date;
12: oRecurr.PatternEndDate = DateTime.Now.Date.AddDays(3);
13:
14: newAppointment.Body = "Test Appointment";
15: newAppointment.AllDayEvent = false;
16: newAppointment.Subject = "Test Appointment";
17: newAppointment.Save();
18: newAppointment.Display(true);
19: }
20: catch (Exception ex)
21: {
22: MessageBox.Show("The following error occurred: " + ex.Message);
23: }
References:
- RecurrenceType Property
https://msdn.microsoft.com/en-us/library/aa171884(office.11).aspx - RecurrencePattern Object
https://msdn.microsoft.com/en-us/library/aa211012(office.11).aspx
Hope this helps.
Comments
- Anonymous
February 07, 2012
With C#, .net 4.0 and Visual Studio 2010, to set DayOfWeekMask to 62,65,127 will cause running time exception. However, with normal Outlook 2010, such setup for a recurring appointment is not a issue. Just wondering if it's a bug with Visual Studio/Office.Interop.Outlook. - Anonymous
February 07, 2012
@Dean, That works fine for me in both VBA for Outlook 2010 and C# with .Net 4 out of VS 2010. Which version of OOM Lib do have reference to in your project?