- December 30, 2024
- Mins Read
Thunder Collection is a useful framework which enables quick and easy creation of collection views in iOS using a declarative approach. It makes the process of creating complex collection views as simple as a few lines of code; and removes the necessity for having long chains of index paths and if statements.
Thunder Collection comprises of two main types of objects:
Collection items are objects that conform to the CollectionItemDisplayable
protocol, this protocol has properties such as: cellClass
, selectionHandler
which are responsible for defining how the cell is configured. As this is a protocol any object can conform to it, which allows you to simply send an array of model objects to the collection view to display your content.
Collection sections are objects that conform to the CollectionSectionDisplayable
protocol, most of the time you won’t need to implement this protocol yourself as Thunder Collection has a convenience class CollectionSection
which can be used in most circumstances. However you can implement more complex layouts using this protocol on your own classes.
Setting up your app to use ThunderCollection is a simple and quick process. You can choose between a manual installation, or use Carthage.
github "3sidedcube/ThunderCollection" == 2.0.0
to your Cartfile.carthage update --platform ios --use-xcframeworks
to fetch the framework.ThunderCollection
into your project’s Frameworks and Libraries section from the Carthage/Build
folder (Embed).import ThunderCollection
.Setting up a collection view is massively simplified using thunder collection, in fact, we can get a simple collection view running with just a few lines of code. To create a custom collection view we subclass from CollectionViewController
. We then set up our collection view in the viewDidLoad:
method. In contrast to ThunderCollection no default implementations of CollectionItemDisplayable
are provided, as there is no standard implementation of UICollectionViewCell
like there is with UITableViewCell
.
import ThunderCollection
class MyCollectionViewController: CollectionViewController {
override func viewDidLoad() {
super.viewDidLoad()
// ImageRow not provided by framework!
let imageRow = ImageRow(image: someImage)
let section = CollectionSection(rows: [imageRow])
data = [section]
}
}