IGListSectionType
@protocol IGListSectionType <NSObject>
Implement this protocol in order to be used within the IGListKit data infrastructure and be registered for use in an IGListAdapter. An IGListSectionType conforming object represents a single instance of an object in a collection of objects.
The infrastructure uses each IGListSectionType conforming object as a view model
to populate and control cells as
part of a section in a UICollectionView feed. IGListSectionType objects should be architected without knowledge of
global
state of the feed they are contained in.
Index paths are used as a convenience for communicating the section index to each section object without allowing each section to mutate its own position within a feed. The row of an index path can be directly mapped to a cell within an IGListSectionType conforming object.
-
The number of items in the IGListSectionType.
@discussion The count returned is used to drive the number of cells displayed for this list. You are free to change this value between data loading passes.
Declaration
Objective-C
- (NSUInteger)numberOfItems;
Swift
func numberOfItems() -> Any!
Return Value
A count of items in the list.
-
The specific size for the item at the specified index.
@discussion The returned size is not garaunteed to be used. The feed implementation may query list items for their layout information at will, or use its own layout metrics. For example, consider a dynamic-text sized feed vs. a fixed height-and-width grid feed. The former will ask each IGListSectionType for a size, and the latter will likely not.
Declaration
Objective-C
- (CGSize)sizeForItemAtIndex:(NSInteger)index;
Swift
func sizeForItem(atIndex index: Any!) -> Any!
Parameters
index
The row index of the item.
Return Value
The size for the item at index.
-
Asks the section controller for a fully configured cell at an index path.
@discussion This is your opportunity to do any cell setup and configuration. The infrastructure requests a cell when it will be used on screen. You should never allocate new cells in this method, instead on the provided adapter call -dequeCellClass:forIndexPath: which either deques a cell from the UICollectionView or creates a new one for you.
Declaration
Objective-C
- (nonnull __kindof UICollectionViewCell *)cellForItemAtIndex:(NSInteger)index;
Swift
func cellForItem(atIndex index: Any!) -> Any!
Parameters
index
The index of the requested row.
Return Value
A configured UICollectionViewCell subclass.
-
Tells the IGListSectionType that the section controller was updated to a new item.
@discussion When this method is called, all available contexts and configurations have been set for the section controller. Also, depending on the updating strategy used, your item models may have changed objects in memory, so you can use this event to update the object stored on your section controller.
This method will only be called when the object instance has changed, either from nil or a previous object.
Declaration
Objective-C
- (void)didUpdateToObject:(nonnull id)object;
Swift
func didUpdate(to object: Any!)
Parameters
object
The object mapped to this section controller.
-
Tells the IGListSectionType that the cell at the specified index path was selected.
@discussion Implementation of this method is required for compile-time safety, but you are free to do nothing.
Declaration
Objective-C
- (void)didSelectItemAtIndex:(NSInteger)index;
Swift
func didSelectItem(atIndex index: Any!)
Parameters
index
The index of the selected cell.