IGListKit/Example/IGListKitExamples/ViewControllers/DemosViewController.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

67 lines
2.9 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 DemosViewController: UIViewController, IGListAdapterDataSource {
lazy var adapter: IGListAdapter = {
return IGListAdapter(updater: IGListAdapterUpdater(), viewController: self, workingRangeSize: 0)
}()
let collectionView = IGListCollectionView(frame: .zero, collectionViewLayout: UICollectionViewFlowLayout())
let demos: [DemoItem] = [
DemoItem(name: "Tail Loading", controllerClass: LoadMoreViewController.self),
DemoItem(name: "Search Autocomplete", controllerClass: SearchViewController.self),
DemoItem(name: "Mixed Data", controllerClass: MixedDataViewController.self),
DemoItem(name: "Nested Adapter", controllerClass: NestedAdapterViewController.self),
DemoItem(name: "Empty View", controllerClass: EmptyViewController.self),
DemoItem(name: "Single Section Controller", controllerClass: SingleSectionViewController.self),
DemoItem(name: "Storyboard", controllerClass: SingleSectionViewController.self, controllerIdentifier: "demo"),
DemoItem(name: "Single Section Storyboard", controllerClass: SingleSectionViewController.self, controllerIdentifier: "singleSectionDemo"),
DemoItem(name: "Working Range", controllerClass: WorkingRangeViewController.self),
DemoItem(name: "Diff Algorithm", controllerClass: DiffTableViewController.self),
DemoItem(name: "Supplementary Views", controllerClass: SupplementaryViewController.self),
DemoItem(name: "Self-sizing cells", controllerClass: SelfSizingCellsViewController.self),
]
override func viewDidLoad() {
super.viewDidLoad()
title = "Demos"
view.addSubview(collectionView)
adapter.collectionView = collectionView
adapter.dataSource = self
}
override func viewDidLayoutSubviews() {
super.viewDidLayoutSubviews()
collectionView.frame = view.bounds
}
//MARK: IGListAdapterDataSource
func objects(for listAdapter: IGListAdapter) -> [IGListDiffable] {
return demos
}
func listAdapter(_ listAdapter: IGListAdapter, sectionControllerFor object: Any) -> IGListSectionController {
return DemoSectionController()
}
func emptyView(for listAdapter: IGListAdapter) -> UIView? {
return nil
}
}