IGListKit/Example/IGListKitExamples/SectionControllers/SelfSizingSectionController.swift
Ryan Nystrom 1950abad4f Example using self sizing cells
Summary:
Adding an example using self sizing cells (`estimatedSize` API of `UICollectionViewFlowLayout`) both in code and from cells in nibs. I assume cells in storyboards would follow the same AL design patterns as nibs, so I left out storyboards.

![simulator screen shot nov 8 2016 11 55 04 am](https://cloud.githubusercontent.com/assets/739696/20108568/7b37ba8c-a5aa-11e6-8323-4ee218e023f3.png)

Fixes #149

- [x] All tests pass. Demo project builds and runs.
- [x] I have reviewed the [contributing guide](https://github.com/Instagram/IGListKit/blob/master/CONTRIBUTING.md)
Closes https://github.com/Instagram/IGListKit/pull/176

Differential Revision: D4156409

Pulled By: rnystrom

fbshipit-source-id: b0b6d0cc8f4a575ff9963d66bc0df605843d47fe
2016-11-09 15:29:19 -08:00

63 lines
2.2 KiB
Swift

/**
Copyright (c) 2016-present, Facebook, Inc. All rights reserved.
The examples provided by Facebook are for non-commercial testing and evaluation
purposes only. Facebook reserves all rights not expressly granted.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
FACEBOOK BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
*/
import UIKit
import IGListKit
final class SelfSizingSectionController: IGListSectionController, IGListSectionType {
var model: SelectionModel!
override init() {
super.init()
inset = UIEdgeInsets(top: 0, left: 0, bottom: 40, right: 0)
minimumLineSpacing = 4
minimumInteritemSpacing = 4
}
func numberOfItems() -> Int {
return model.options.count
}
func sizeForItem(at index: Int) -> CGSize {
return CGSize(width: collectionContext!.containerSize.width, height: 55)
}
func cellForItem(at index: Int) -> UICollectionViewCell {
let text = model.options[index]
let cell: UICollectionViewCell
switch model.type {
case .none:
let manualCell = collectionContext!.dequeueReusableCell(of: ManuallySelfSizingCell.self, for: self, at: index) as! ManuallySelfSizingCell
manualCell.label.text = text
cell = manualCell
case .fullWidth:
let manualCell = collectionContext!.dequeueReusableCell(of: FullWidthSelfSizingCell.self, for: self, at: index) as! FullWidthSelfSizingCell
manualCell.label.text = text
cell = manualCell
case .nib:
let nibCell = collectionContext!.dequeueReusableCell(withNibName: "NibSelfSizingCell", bundle: nil, for: self, at: index) as! NibSelfSizingCell
nibCell.contentLabel.text = text
cell = nibCell
}
return cell
}
func didUpdate(to object: Any) {
self.model = object as? SelectionModel
}
func didSelectItem(at index: Int) {}
}