Where are my local calendars?
Q: EKEventStore's calendarsForEntityType does not return my local calendars when iCloud calendars are enabled on my device. They also do not appear among the calendars in the Calendar application. Where are they?
A: That is the expected behavior when your local calendars do not have any events. When you enable calendars for a remote account such as iCloud or Exchange in the Settings application on your device as shown in Figure 1, we check whether any of your local calendars have events.
data:image/s3,"s3://crabby-images/febfc/febfc5afcade432c202a31f5c1185a4f9a8495e2" alt=""
data:image/s3,"s3://crabby-images/b07f6/b07f66c7347935599a6fb3a1620875995916796c" alt=""
data:image/s3,"s3://crabby-images/b07f6/b07f66c7347935599a6fb3a1620875995916796c" alt=""
Listing 1 Running EKEventStore's calendarsForEntityType show these calendars and their type is local.
extension EKCalendar |
{ |
/// - returns: The name matching a given calendar type. |
var nameMatchingCalendarType: String |
{ |
switch self.type |
{ |
case .Local: return "A local calendar." |
case .CalDAV: return "A CalDAV or iCloud calendar." |
case .Exchange: return "An Exchange calendar." |
case .Subscription: return "A locally subscribed calendar." |
case .Birthday: return "A birthday calendar." |
} |
} |
} |
// Fetch all event calendars |
let calendars = self.eventStore.calendarsForEntityType(.Event) |
// Display all returned calendars |
for calendar in calendars |
{ |
print("Calendar: \(calendar.title) Type: \(calendar.nameMatchingCalendarType)") |
} |
// Calendar: US Holidays Type: A locally subscribed calendar. |
// Calendar: EmptyLocalCalendar Type: A local calendar. |
// Calendar: LocalCalendarWithEvents Type: A local calendar. |
// Calendar: Birthdays Type: A birthday calendar. |
We offer to remove or migrate your local calendars to the remote account if any of them has events as shown in Figure 3.
data:image/s3,"s3://crabby-images/ff479/ff479bf9b7aca4d59e489b400b9e4c26acfe1055" alt=""
data:image/s3,"s3://crabby-images/ff479/ff479bf9b7aca4d59e489b400b9e4c26acfe1055" alt=""
Listing 2 After enabling calendars for iCloud, running EKEventStore's calendarsForEntityType show these calendars with a CalDAV or iCloud type.
extension EKCalendar |
{ |
/// - returns: The name matching a given calendar type. |
var nameMatchingCalendarType: String |
{ |
switch self.type |
{ |
case .Local: return "A local calendar." |
case .CalDAV: return "A CalDAV or iCloud calendar." |
case .Exchange: return "An Exchange calendar." |
case .Subscription: return "A locally subscribed calendar." |
case .Birthday: return "A birthday calendar." |
} |
} |
} |
// Fetch all event calendars |
let calendars = self.eventStore.calendarsForEntityType(.Event) |
// Display all returned calendars |
for calendar in calendars |
{ |
print("Calendar: \(calendar.title) Type: \(calendar.nameMatchingCalendarType)") |
} |
// Calendar: US Holidays Type: A locally subscribed calendar. |
// Calendar: Trips Type: A CalDAV or iCloud calendar. |
// Calendar: EmptyLocalCalendar Type: A CalDAV or iCloud calendar. |
// Calendar: LocalCalendarWithEvents Type: A CalDAV or iCloud calendar. |
// Calendar: Meetings Type: A CalDAV or iCloud calendar. |
// Calendar: Birthdays Type: A birthday calendar. |
We hide your local calendars if they are empty as shown in Figure 4 and Listing 3.
data:image/s3,"s3://crabby-images/0a861/0a861b6ae74befc590c9aefc4c7a723e77e67361" alt=""
data:image/s3,"s3://crabby-images/0a861/0a861b6ae74befc590c9aefc4c7a723e77e67361" alt=""
Listing 3 Running EKEventStore's calendarsForEntityType does not show EmptyLocalCalendar.
extension EKCalendar |
{ |
/// - returns: The name matching a given calendar type. |
var nameMatchingCalendarType: String |
{ |
switch self.type |
{ |
case .Local: return "A local calendar." |
case .CalDAV: return "A CalDAV or iCloud calendar." |
case .Exchange: return "An Exchange calendar." |
case .Subscription: return "A locally subscribed calendar." |
case .Birthday: return "A birthday calendar." |
} |
} |
} |
// Fetch all event calendars |
let calendars = self.eventStore.calendarsForEntityType(.Event) |
// Display all returned calendars |
for calendar in calendars |
{ |
print("Calendar: \(calendar.title) Type: \(calendar.nameMatchingCalendarType)") |
} |
// Calendar: US Holidays Type: A locally subscribed calendar. |
// Calendar: Trips Type: A CalDAV or iCloud calendar. |
// Calendar: Meetings Type: A CalDAV or iCloud calendar. |
// Calendar: Birthdays Type: A birthday calendar. |
Disable calendars for your remote account in the Settings app on your device to view your local calendars.
Document Revision History
Date | Notes |
---|---|
2016-07-05 | New document that explains why local calendars are hidden when enabling calendars for remote source accounts on a device. |
Copyright © 2016 Apple Inc. All Rights Reserved. Terms of Use | Privacy Policy | Updated: 2016-07-05