Skip to content

Keeps track of pagination for tableview and collection view

License

Notifications You must be signed in to change notification settings

mstfy/AsyncPager

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

2 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

What is it?

AsyncPager is an objective-c micro library that helps pagination in tableviews and collection views. It tracks current page and calls your api to load next page so you don't need to keep track of that. It is inspired from this blog post.

###How to install? AsyncPager supports Carthage. Just add the following line to your Cartfile

github "mstfy/AsyncPager"

###How to use? First create a property that holds instance of AsyncPager inside your view controller

@property (nonatomic, strong) AsyncPager *pager;

Then initialize it inside viewDidLoad

self.pager = [[AsyncPager alloc] initWithOffset:0 andLimit:25];

First parameter is the current page and the second one is item count per page.

Here is the important part. When you are loading items for next page from api wrap that with async pager.

__weak typeof(self) weakSelf = self;
[self.pager next:^(int offset, int limit, AsyncPagerCompletionBlock completion) {
	// Here is my api method that loads items
    [weakSelf loadItemsInRange:NSMakeRange(offset, limit) completion:^(NSArray *items, NSError *error) {
        completion(items);
    }];
} onFinish:^(NSArray *items) {
    [weakSelf.items addObjectsFromArray:items];
    [weakSelf.tableView reloadData];
}];

This is the only method that AsyncPager has. Inside next block you call your api method to load items. After you download your items call completion block. After you call completion block AsyncPager will call `onFinish' block with newly loaded items. Here you can update your ui with new items.

###License AsyncPager is released under the MIT license. See LICENSE for details.

About

Keeps track of pagination for tableview and collection view

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published