Improvements to store migration.
[IMPROVED] Don't ask to migrate store when there's no sites in it.
This commit is contained in:
parent
32ec0038b6
commit
40d6019f71
2
External/UbiquityStoreManager
vendored
2
External/UbiquityStoreManager
vendored
@ -1 +1 @@
|
|||||||
Subproject commit 5d0bb4c2eacba5098b3f54ac182dbbf7725a89db
|
Subproject commit fb1b53869cee17efcc5b5a3b4232392fb006c463
|
@ -596,8 +596,26 @@
|
|||||||
if (iCloudEnabled != cloudEnabled) {
|
if (iCloudEnabled != cloudEnabled) {
|
||||||
if ([[MPiOSConfig get].iCloudEnabled boolValue])
|
if ([[MPiOSConfig get].iCloudEnabled boolValue])
|
||||||
[self.storeManager setCloudEnabledAndOverwriteCloudWithLocalIfConfirmed:^(void (^setConfirmationAnswer)(BOOL answer)) {
|
[self.storeManager setCloudEnabledAndOverwriteCloudWithLocalIfConfirmed:^(void (^setConfirmationAnswer)(BOOL answer)) {
|
||||||
[PearlAlert showAlertWithTitle:@"Keep Sites?"
|
__block NSUInteger siteCount = NSNotFound;
|
||||||
message:@"You can either revert to your old iCloud sites or overwrite them with your current sites."
|
[MPAppDelegate_Shared managedObjectContextPerformBlockAndWait:^(NSManagedObjectContext *context) {
|
||||||
|
NSFetchRequest *fetchRequest = [NSFetchRequest fetchRequestWithEntityName:NSStringFromClass( [MPElementEntity class] )];
|
||||||
|
NSError *error = nil;
|
||||||
|
if ((siteCount = [context countForFetchRequest:fetchRequest error:&error]) == NSNotFound) {
|
||||||
|
wrn(@"Couldn't count current sites: %@", error);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}];
|
||||||
|
|
||||||
|
// If we currently have no sites, don't bother asking to copy them.
|
||||||
|
if (siteCount == 0) {
|
||||||
|
setConfirmationAnswer( NO );
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// The current store has sites, ask the user if he wants to copy them to the cloud
|
||||||
|
[PearlAlert showAlertWithTitle:@"Copy Sites To iCloud?"
|
||||||
|
message:@"You can either switch to your old iCloud sites "
|
||||||
|
@"or overwrite them with your current sites."
|
||||||
viewStyle:UIAlertViewStyleDefault initAlert:nil
|
viewStyle:UIAlertViewStyleDefault initAlert:nil
|
||||||
tappedButtonBlock:^(UIAlertView *alert, NSInteger buttonIndex) {
|
tappedButtonBlock:^(UIAlertView *alert, NSInteger buttonIndex) {
|
||||||
if (buttonIndex == [alert cancelButtonIndex])
|
if (buttonIndex == [alert cancelButtonIndex])
|
||||||
@ -605,12 +623,29 @@
|
|||||||
if (buttonIndex == [alert firstOtherButtonIndex])
|
if (buttonIndex == [alert firstOtherButtonIndex])
|
||||||
setConfirmationAnswer( YES );
|
setConfirmationAnswer( YES );
|
||||||
}
|
}
|
||||||
cancelTitle:@"Revert" otherTitles:@"Replace iCloud", nil];
|
cancelTitle:@"Use Old" otherTitles:@"Overwrite", nil];
|
||||||
}];
|
}];
|
||||||
else
|
else
|
||||||
[self.storeManager setCloudDisabledAndOverwriteLocalWithCloudIfConfirmed:^(void (^setConfirmationAnswer)(BOOL answer)) {
|
[self.storeManager setCloudDisabledAndOverwriteLocalWithCloudIfConfirmed:^(void (^setConfirmationAnswer)(BOOL answer)) {
|
||||||
[PearlAlert showAlertWithTitle:@"Keep iCloud Sites?"
|
__block NSUInteger siteCount = NSNotFound;
|
||||||
message:@"You can either revert to your old sites or overwrite them with your current iCloud sites."
|
[MPAppDelegate_Shared managedObjectContextPerformBlockAndWait:^(NSManagedObjectContext *context) {
|
||||||
|
NSFetchRequest *fetchRequest = [NSFetchRequest fetchRequestWithEntityName:NSStringFromClass( [MPElementEntity class] )];
|
||||||
|
NSError *error = nil;
|
||||||
|
if ((siteCount = [context countForFetchRequest:fetchRequest error:&error]) == NSNotFound) {
|
||||||
|
wrn(@"Couldn't count current sites: %@", error);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}];
|
||||||
|
|
||||||
|
// If we currently have no sites, don't bother asking to copy them.
|
||||||
|
if (siteCount == 0) {
|
||||||
|
setConfirmationAnswer( NO );
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
[PearlAlert showAlertWithTitle:@"Copy iCloud Sites?"
|
||||||
|
message:@"You can either switch to the old sites on your device "
|
||||||
|
@"or overwrite them with your current iCloud sites."
|
||||||
viewStyle:UIAlertViewStyleDefault initAlert:nil
|
viewStyle:UIAlertViewStyleDefault initAlert:nil
|
||||||
tappedButtonBlock:^(UIAlertView *alert, NSInteger buttonIndex) {
|
tappedButtonBlock:^(UIAlertView *alert, NSInteger buttonIndex) {
|
||||||
if (buttonIndex == [alert cancelButtonIndex])
|
if (buttonIndex == [alert cancelButtonIndex])
|
||||||
@ -618,7 +653,7 @@
|
|||||||
if (buttonIndex == [alert firstOtherButtonIndex])
|
if (buttonIndex == [alert firstOtherButtonIndex])
|
||||||
setConfirmationAnswer( YES );
|
setConfirmationAnswer( YES );
|
||||||
}
|
}
|
||||||
cancelTitle:@"Revert" otherTitles:@"Copy iCloud", nil];
|
cancelTitle:@"Use Old" otherTitles:@"Overwrite", nil];
|
||||||
}];
|
}];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user