diff --git a/Podfile b/Podfile index 18d09a99e976..39c8caae468b 100644 --- a/Podfile +++ b/Podfile @@ -47,7 +47,7 @@ def wordpress_ui end def wordpress_kit - pod 'WordPressKit', '~> 4.43.0' + pod 'WordPressKit', '~> 4.44.0-beta' # pod 'WordPressKit', :git => 'https://github.com/wordpress-mobile/WordPressKit-iOS.git', :tag => '' # pod 'WordPressKit', :git => 'https://github.com/wordpress-mobile/WordPressKit-iOS.git', :branch => '' # pod 'WordPressKit', :git => 'https://github.com/wordpress-mobile/WordPressKit-iOS.git', :commit => '' diff --git a/Podfile.lock b/Podfile.lock index 12eab5f0ff27..c06f5a7f2247 100644 --- a/Podfile.lock +++ b/Podfile.lock @@ -452,7 +452,7 @@ PODS: - WordPressKit (~> 4.18-beta) - WordPressShared (~> 1.12-beta) - WordPressUI (~> 1.7-beta) - - WordPressKit (4.43.0): + - WordPressKit (4.44.0-beta.1): - Alamofire (~> 4.8.0) - CocoaLumberjack (~> 3.4) - NSObject-SafeExpectations (= 0.0.4) @@ -553,7 +553,7 @@ DEPENDENCIES: - SVProgressHUD (= 2.2.5) - WordPress-Editor-iOS (~> 1.19.5) - WordPressAuthenticator (~> 1.42.1) - - WordPressKit (~> 4.43.0) + - WordPressKit (~> 4.44.0-beta) - WordPressMocks (~> 0.0.15) - WordPressShared (~> 1.16.2) - WordPressUI (~> 1.12.2) @@ -810,7 +810,7 @@ SPEC CHECKSUMS: WordPress-Aztec-iOS: af36d9cb86a0109b568f516874870e2801ba1bd9 WordPress-Editor-iOS: 446be349b94707c1a82a83d525b86dbcf18cf2c7 WordPressAuthenticator: 111793c08fa8e9d9a72aed5b33a094c91ff4fd82 - WordPressKit: ea1b285bae9156e387ddcbe2a7f919c0783a9b91 + WordPressKit: 7fe46752fe65808f80163ae135bb5c3f081d108b WordPressMocks: 6b52b0764d9939408151367dd9c6e8a910877f4d WordPressShared: 6f4d949aa3ec8c3b9c24f5aa601473f087badd24 WordPressUI: c573f4b5c2e5d0ffcebe69ecf86ae75ab7b6ff4d @@ -826,6 +826,6 @@ SPEC CHECKSUMS: ZendeskSupportSDK: 3a8e508ab1d9dd22dc038df6c694466414e037ba ZIPFoundation: e27423c004a5a1410c15933407747374e7c6cb6e -PODFILE CHECKSUM: 05f1d233304eca44dd7b86f86e966d786c29c86f +PODFILE CHECKSUM: 70e2c1b2bb057852c4af271041294e98678f6963 COCOAPODS: 1.10.1 diff --git a/WordPress/Classes/Services/CommentService.h b/WordPress/Classes/Services/CommentService.h index 1fbda41a1c76..9ce6da001af3 100644 --- a/WordPress/Classes/Services/CommentService.h +++ b/WordPress/Classes/Services/CommentService.h @@ -95,10 +95,16 @@ extern NSUInteger const WPTopLevelHierarchicalCommentsPerPage; success:(void (^)(void))success failure:(void (^)(NSError *error))failure; -// Sync a list of comments sorted by hierarchy +// Sync a list of comments sorted by hierarchy, fetched by page number. - (void)syncHierarchicalCommentsForPost:(ReaderPost *)post page:(NSUInteger)page - success:(void (^)(NSInteger count, BOOL hasMore))success + success:(void (^)(BOOL hasMore, NSNumber *totalComments))success + failure:(void (^)(NSError *error))failure; + +// Sync a list of comments sorted by hierarchy, restricted by the specified number of _top level_ comments. +- (void)syncHierarchicalCommentsForPost:(ReaderPost *)post + numberTopLevelComments:(NSUInteger)number + success:(void (^)(BOOL hasMore, NSNumber *totalComments))success failure:(void (^)(NSError *error))failure; // Counts and returns the number of full pages of hierarchcial comments synced for a post. diff --git a/WordPress/Classes/Services/CommentService.m b/WordPress/Classes/Services/CommentService.m index 8c36f925aa39..4e02359d9b60 100644 --- a/WordPress/Classes/Services/CommentService.m +++ b/WordPress/Classes/Services/CommentService.m @@ -512,18 +512,47 @@ - (void)deleteComment:(Comment *)comment - (void)syncHierarchicalCommentsForPost:(ReaderPost *)post page:(NSUInteger)page - success:(void (^)(NSInteger count, BOOL hasMore))success + success:(void (^)(BOOL hasMore, NSNumber *totalComments))success + failure:(void (^)(NSError *error))failure +{ + [self syncHierarchicalCommentsForPost:post + page:page + numberTopLevelComments:WPTopLevelHierarchicalCommentsPerPage + success:success + failure:failure]; +} + +- (void)syncHierarchicalCommentsForPost:(ReaderPost *)post + number:(NSUInteger)number + success:(void (^)(BOOL hasMore, NSNumber *totalComments))success + failure:(void (^)(NSError *error))failure +{ + [self syncHierarchicalCommentsForPost:post + page:1 + numberTopLevelComments:number + success:success + failure:failure]; +} + +- (void)syncHierarchicalCommentsForPost:(ReaderPost *)post + page:(NSUInteger)page + numberTopLevelComments:(NSUInteger)number + success:(void (^)(BOOL hasMore, NSNumber *totalComments))success failure:(void (^)(NSError *error))failure { NSManagedObjectID *postObjectID = post.objectID; NSNumber *siteID = post.siteID; NSNumber *postID = post.postID; + + NSUInteger commentsPerPage = number ?: WPTopLevelHierarchicalCommentsPerPage; + NSUInteger pageNumber = page ?: 1; + [self.managedObjectContext performBlock:^{ CommentServiceRemoteREST *service = [self restRemoteForSite:siteID]; [service syncHierarchicalCommentsForPost:postID - page:page - number:WPTopLevelHierarchicalCommentsPerPage - success:^(NSArray *comments) { + page:pageNumber + number:commentsPerPage + success:^(NSArray *comments, NSNumber *totalComments) { [self.managedObjectContext performBlock:^{ NSError *error; ReaderPost *aPost = (ReaderPost *)[self.managedObjectContext existingObjectWithID:postObjectID error:&error]; @@ -554,7 +583,7 @@ - (void)syncHierarchicalCommentsForPost:(ReaderPost *)post } dispatch_async(dispatch_get_main_queue(), ^{ - success([comments count], hasMore); + success(hasMore, totalComments); }); }]; }]; diff --git a/WordPress/Classes/ViewRelated/Reader/ReaderCommentsViewController.m b/WordPress/Classes/ViewRelated/Reader/ReaderCommentsViewController.m index ba5c4efc8c65..e546e2672563 100644 --- a/WordPress/Classes/ViewRelated/Reader/ReaderCommentsViewController.m +++ b/WordPress/Classes/ViewRelated/Reader/ReaderCommentsViewController.m @@ -978,7 +978,7 @@ - (void)syncHelper:(WPContentSyncHelper *)syncHelper syncContentWithUserInteract { self.failedToFetchComments = NO; CommentService *service = [[CommentService alloc] initWithManagedObjectContext:[[ContextManager sharedInstance] newDerivedContext]]; - [service syncHierarchicalCommentsForPost:self.post page:1 success:^(NSInteger count, BOOL hasMore) { + [service syncHierarchicalCommentsForPost:self.post page:1 success:^(BOOL hasMore, NSNumber *totalComments) { if (success) { success(hasMore); } @@ -993,7 +993,7 @@ - (void)syncHelper:(WPContentSyncHelper *)syncHelper syncMoreWithSuccess:(void ( CommentService *service = [[CommentService alloc] initWithManagedObjectContext:[[ContextManager sharedInstance] newDerivedContext]]; NSInteger page = [service numberOfHierarchicalPagesSyncedforPost:self.post] + 1; - [service syncHierarchicalCommentsForPost:self.post page:page success:^(NSInteger count, BOOL hasMore) { + [service syncHierarchicalCommentsForPost:self.post page:page success:^(BOOL hasMore, NSNumber *totalComments) { if (success) { success(hasMore); }