IGListUpdatingDelegate
Objective-C
@protocol IGListUpdatingDelegate <NSObject>
                Swift
protocol ListUpdatingDelegate : NSObjectProtocol
                Implement this protocol in order to handle both section and row based update events. Implementation should forward or coalesce these events to a backing store or collection.
- 
                  
                  
Asks the delegate for the pointer functions for looking up an object in a collection.
Note
Since the updating delegate is responsible for transitioning between object sets, it becomes the “source of truth” for how objects and their corresponding section controllers are mapped. This allows the updater to control if objects are looked up by pointer, or more traditionally, with
-hash/-isEqual.For behavior similar to
NSDictionary, simply return+[NSPointerFunctions pointerFunctionsWithOptions:NSPointerFunctionsObjectPersonality].Declaration
Objective-C
- (nonnull NSPointerFunctions *)objectLookupPointerFunctions;Swift
func objectLookupPointerFunctions() -> NSPointerFunctionsReturn Value
Pointer functions for looking up an object in a collection.
 - 
                  
                  
Perform a section update from an old array of objects to a new one.
Note
Implementations determine how to transition between objects. You can perform a diff on the objects, reload each section, or simply call
-reloadDataon the collection view. In the end, the collection view must be setup with a section for each object in thetoObjectsarray.The
applySectionDataBlockblock should be called prior to making anyUICollectionViewupdates, passing in thetoObjectsthat the updater is applying.Declaration
Objective-C
- (void)performUpdateWithCollectionViewBlock: (nonnull IGListCollectionViewBlock)collectionViewBlock animated:(BOOL)animated sectionDataBlock:(nonnull IGListTransitionDataBlock) sectionDataBlock applySectionDataBlock: (nonnull IGListTransitionDataApplyBlock) applySectionDataBlock completion:(nullable IGListUpdatingCompletion) completion;Swift
func performUpdate(collectionViewBlock: @escaping ListCollectionViewBlock, animated: Bool, sectionDataBlock: @escaping ListTransitionDataBlock, applySectionDataBlock: @escaping ListTransitionDataApplyBlock) async -> BoolParameters
collectionViewBlockA block returning the collecion view to perform updates on.
animatedA flag indicating if the transition should be animated.
sectionDataBlockA block that returns the section information (ex: from and to objects)
applySectionDataBlockA block that must be called when the adapter applies changes to the collection view.
completionA completion block to execute when the update is finished.
 - 
                  
                  
Perform an item update block in the collection view.
Declaration
Objective-C
- (void)performUpdateWithCollectionViewBlock: (nonnull IGListCollectionViewBlock)collectionViewBlock animated:(BOOL)animated itemUpdates: (nonnull IGListItemUpdateBlock)itemUpdates completion:(nullable IGListUpdatingCompletion) completion;Swift
func performUpdate(collectionViewBlock: @escaping ListCollectionViewBlock, animated: Bool, itemUpdates: @escaping ListItemUpdateBlock) async -> BoolParameters
collectionViewBlockA block returning the collecion view to perform updates on.
animatedA flag indicating if the transition should be animated.
itemUpdatesA block containing all of the updates.
completionA completion block to execute when the update is finished.
 - 
                  
                  
Perform a
[UICollectionView setDataSource:...]swap within this block. It gives the updater the chance to cancel or execute any on-going updates. The block should be executed synchronously.Declaration
Objective-C
- (void)performDataSourceChange:(nonnull IGListDataSourceChangeBlock)block;Swift
func performDataSourceChange(_ block: @escaping ListDataSourceChangeBlock)Parameters
blockThe block that will actuallty change the
dataSource - 
                  
                  
Completely reload data in the collection.
Declaration
Objective-C
- (void)reloadDataWithCollectionViewBlock: (nonnull IGListCollectionViewBlock)collectionViewBlock reloadUpdateBlock: (nonnull IGListReloadUpdateBlock)reloadUpdateBlock completion:(nullable IGListUpdatingCompletion) completion;Swift
func reloadData(collectionViewBlock: @escaping ListCollectionViewBlock, reloadUpdate reloadUpdateBlock: @escaping ListReloadUpdateBlock) async -> BoolParameters
collectionViewBlockA block returning the collecion view to reload.
reloadUpdateBlockA block that must be called when the adapter reloads the collection view.
completionA completion block to execute when the reload is finished.
 - 
                  
                  
Tells the delegate to perform item inserts at the given index paths.
Declaration
Objective-C
- (void)insertItemsIntoCollectionView:(nonnull UICollectionView *)collectionView indexPaths: (nonnull NSArray<NSIndexPath *> *)indexPaths;Swift
func insertItems(into collectionView: UICollectionView, indexPaths: [IndexPath])Parameters
collectionViewThe collection view on which to perform the transition.
indexPathsThe index paths to insert items into.
 - 
                  
                  
Tells the delegate to perform item deletes at the given index paths.
Declaration
Objective-C
- (void)deleteItemsFromCollectionView:(nonnull UICollectionView *)collectionView indexPaths: (nonnull NSArray<NSIndexPath *> *)indexPaths;Swift
func deleteItems(from collectionView: UICollectionView, indexPaths: [IndexPath])Parameters
collectionViewThe collection view on which to perform the transition.
indexPathsThe index paths to delete items from.
 - 
                  
                  
Tells the delegate to move an item from and to given index paths.
Declaration
Objective-C
- (void)moveItemInCollectionView:(nonnull UICollectionView *)collectionView fromIndexPath:(nonnull NSIndexPath *)fromIndexPath toIndexPath:(nonnull NSIndexPath *)toIndexPath;Swift
func moveItem(in collectionView: UICollectionView, from fromIndexPath: IndexPath, to toIndexPath: IndexPath)Parameters
collectionViewThe collection view on which to perform the transition.
fromIndexPathThe source index path of the item to move.
toIndexPathThe destination index path of the item to move.
 - 
                  
                  
Tells the delegate to reload an item from and to given index paths.
Note
Since UICollectionView is unable to handle calling -[UICollectionView reloadItemsAtIndexPaths:] safely while also executing insert and delete operations in the same batch updates, the updater must know about the origin and destination of the reload to perform a safe transition.
Declaration
Objective-C
- (void)reloadItemInCollectionView:(nonnull UICollectionView *)collectionView fromIndexPath:(nonnull NSIndexPath *)fromIndexPath toIndexPath:(nonnull NSIndexPath *)toIndexPath;Swift
func reloadItem(in collectionView: UICollectionView, from fromIndexPath: IndexPath, to toIndexPath: IndexPath)Parameters
collectionViewThe collection view on which to perform the transition.
fromIndexPathThe source index path of the item to reload.
toIndexPathThe destination index path of the item to reload.
 - 
                  
                  
Tells the delegate to move a section from and to given indexes.
Declaration
Objective-C
- (void)moveSectionInCollectionView:(nonnull UICollectionView *)collectionView fromIndex:(NSInteger)fromIndex toIndex:(NSInteger)toIndex;Swift
func moveSection(in collectionView: UICollectionView, from fromIndex: Int, to toIndex: Int)Parameters
collectionViewThe collection view on which to perform the transition.
fromIndexThe source index of the section to move.
toIndexThe destination index of the section to move.
 - 
                  
                  
Completely reload each section in the collection view.
Declaration
Objective-C
- (void)reloadCollectionView:(nonnull UICollectionView *)collectionView sections:(nonnull NSIndexSet *)sections;Swift
func reload(_ collectionView: UICollectionView, sections: IndexSet)Parameters
collectionViewThe collection view to reload.
sectionsThe sections to reload.
 - 
                  
                  
True if the updater is currently updating the source of truth, like executing applySectionDataBlock and itemUpdates just before updating the UICollectionView.
Declaration
Objective-C
- (BOOL)isInDataUpdateBlock;Swift
func isInDataUpdateBlock() -> Bool 
View on GitHub