IGListUpdatingDelegate

@protocol IGListUpdatingDelegate <NSObject>

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() -> NSPointerFunctions

    Return Value

    Pointer functions for looking up an object in a collection.

  • Tells the delegate to perform a section transition 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 -reloadData on the collection view. In the end, the collection view must be setup with a section for each object in the toObjects array.

    The objectTransitionBlock block should be called prior to making any UICollectionView updates, passing in the toObjects that the updater is applying.

    Declaration

    Objective-C

    - (void)
    performUpdateWithCollectionView:(nonnull UICollectionView *)collectionView
                        fromObjects:
                            (nullable NSArray<id<IGListDiffable>> *)fromObjects
                          toObjects:
                              (nullable NSArray<id<IGListDiffable>> *)toObjects
                           animated:(BOOL)animated
              objectTransitionBlock:
                  (nonnull IGListObjectTransitionBlock)objectTransitionBlock
                         completion:(nullable IGListUpdatingCompletion)completion;

    Parameters

    collectionView

    The collection view to perform the transition on.

    fromObjects

    The previous objects in the collection view. Objects must conform to IGListDiffable.

    toObjects

    The new objects in collection view. Objects must conform to IGListDiffable.

    animated

    A flag indicating if the transition should be animated.

    objectTransitionBlock

    A block that must be called when the adapter applies changes to the collection view.

    completion

    A completion block to execute when the update 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

    collectionView

    The collection view on which to perform the transition.

    indexPaths

    The 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

    collectionView

    The collection view on which to perform the transition.

    indexPaths

    The 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

    collectionView

    The collection view on which to perform the transition.

    fromIndexPath

    The source index path of the item to move.

    toIndexPath

    The 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

    collectionView

    The collection view on which to perform the transition.

    fromIndexPath

    The source index path of the item to reload.

    toIndexPath

    The destination index path of the item to reload.

  • Completely reload data in the collection.

    Declaration

    Objective-C

    - (void)
    reloadDataWithCollectionView:(nonnull UICollectionView *)collectionView
               reloadUpdateBlock:(nonnull IGListReloadUpdateBlock)reloadUpdateBlock
                      completion:(nullable IGListUpdatingCompletion)completion;

    Swift

    func reloadData(with collectionView: UICollectionView, reloadUpdate reloadUpdateBlock: @escaping ListReloadUpdateBlock, completion: ListUpdatingCompletion? = nil)

    Parameters

    collectionView

    The collection view to reload.

    reloadUpdateBlock

    A block that must be called when the adapter reloads the collection view.

    completion

    A completion block to execute when the reload is finished.

  • 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

    collectionView

    The collection view to reload.

    sections

    The sections to reload.

  • Perform an item update block in the collection view.

    Declaration

    Objective-C

    - (void)
    performUpdateWithCollectionView:(nonnull UICollectionView *)collectionView
                           animated:(BOOL)animated
                        itemUpdates:(nonnull IGListItemUpdateBlock)itemUpdates
                         completion:(nullable IGListUpdatingCompletion)completion;

    Swift

    func performUpdate(with collectionView: UICollectionView, animated: Bool, itemUpdates: @escaping ListItemUpdateBlock, completion: ListUpdatingCompletion? = nil)

    Parameters

    collectionView

    The collection view to update.

    animated

    A flag indicating if the transition should be animated.

    itemUpdates

    A block containing all of the updates.

    completion

    A completion block to execute when the update is finished.