mirror of
https://github.com/Instagram/IGListKit
synced 2026-05-10 11:00:46 +00:00
Summary: Replaces #642, #681 Issue ref: #394 Changes from last PR: - Deleted the shared SwiftLint folder, incl. all files (On the plus side, did this in the quest to get this PR in https://github.com/realm/SwiftLint/pull/1513) - Changed the build script such that it runs the user's `HomeBrew` installation of SwiftLint instead of the local copy Integrates SwiftLint into DangerBot. You may want to append a ?w=1 to the end of the files-changed url to exclude whitespace-only changes. - [ ] All tests pass. Demo project builds and runs. - [ ] I added tests, an experiment, or detailed why my change isn't tested. - [ ] I added an entry to the `CHANGELOG.md` for any breaking changes, enhancements, or bug fixes. - [ ] I have reviewed the [contributing guide](https://github.com/Instagram/IGListKit/blob/master/.github/CONTRIBUTING.md) Closes https://github.com/Instagram/IGListKit/pull/741 Differential Revision: D5068134 Pulled By: jessesquires fbshipit-source-id: 68d6a57e0072672e38eeb94908d00f26bbd68fbc
69 lines
2.8 KiB
Swift
69 lines
2.8 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 SingleSectionStoryboardViewController: UIViewController, ListAdapterDataSource, ListSingleSectionControllerDelegate {
|
|
|
|
lazy var adapter: ListAdapter = {
|
|
return ListAdapter(updater: ListAdapterUpdater(), viewController: self)
|
|
}()
|
|
|
|
@IBOutlet weak var collectionView: UICollectionView!
|
|
|
|
let data = Array(0..<20)
|
|
|
|
// MARK: - Lifecycle
|
|
|
|
override func viewDidLoad() {
|
|
super.viewDidLoad()
|
|
adapter.collectionView = collectionView
|
|
adapter.dataSource = self
|
|
}
|
|
|
|
// MARK: - ListAdapterDataSource
|
|
|
|
func objects(for listAdapter: ListAdapter) -> [ListDiffable] {
|
|
return data as [ListDiffable]
|
|
}
|
|
|
|
func listAdapter(_ listAdapter: ListAdapter, sectionControllerFor object: Any) -> ListSectionController {
|
|
let configureBlock = { (item: Any, cell: UICollectionViewCell) in
|
|
guard let cell = cell as? StoryboardCell, let number = item as? Int else { return }
|
|
cell.text = "Cell: \(number + 1)"
|
|
}
|
|
let sizeBlock = { (item: Any, context: ListCollectionContext?) -> CGSize in
|
|
guard let context = context else { return .zero }
|
|
return CGSize(width: context.containerSize.width, height: 44)
|
|
}
|
|
let sectionController = ListSingleSectionController(storyboardCellIdentifier: "cell",
|
|
configureBlock: configureBlock,
|
|
sizeBlock: sizeBlock)
|
|
sectionController.selectionDelegate = self
|
|
return sectionController
|
|
}
|
|
|
|
func emptyView(for listAdapter: ListAdapter) -> UIView? { return nil }
|
|
|
|
// MARK: - ListSingleSectionControllerDelegate
|
|
|
|
func didSelect(_ sectionController: ListSingleSectionController, with object: Any) {
|
|
let section = adapter.section(for: sectionController) + 1
|
|
let alert = UIAlertController(title: "Section \(section) was selected \u{1F389}", message: nil, preferredStyle: .alert)
|
|
alert.addAction(UIAlertAction(title: "Dismiss", style: .default, handler: nil))
|
|
present(alert, animated: true, completion: nil)
|
|
}
|
|
|
|
}
|