2016-10-25 22:17:45 +00:00
|
|
|
/**
|
|
|
|
|
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 IGListKit
|
2018-01-22 20:01:53 +00:00
|
|
|
import UIKit
|
2016-10-25 22:17:45 +00:00
|
|
|
|
Swift name annotations
Summary:
This adds `NS_SWIFT_NAME` annotations to all public API's to provide cleaner integration into Swift:
- Removes the need to prefix classes in Swift code, instead rely on Swift module name spacing
- Adds more argument labels to C function API's like `IGListDiff([], [], .equality)` => `ListDiff(oldArray: [], newArray: [], option: .equality)`
While this is a large API change it should be as easy as:
- Find and replace `(IGList)([^K])` to `List$2` in Xcode with a scope set to Swift
- Build and follow compiler's auto fix corrections for C API's or any missed renames
I have not updated the documentation to reflect this yet, I am totally willing to do so but before I sink that amount of time into it I wanted to see if the Instagram team is even open to this change!
- [x] All tests pass. Demo project builds and runs.
- [x] I added tests, an experiment, or detailed why my change isn't tested.
- [x] I added an entry to the `CHANGELOG.md` for any breaking changes, enhancements, or bug fixes.
- [x] I have reviewed the [contributing guide](https://github.com/Instagram/IGListKit/blob/master/.github/CONTRIBUTING.md)
- [ ] I have updated the documentation
Closes https://github.com/Instagram/IGListKit/pull/593
Reviewed By: jessesquires
Differential Revision: D5028039
Pulled By: rnystrom
fbshipit-source-id: b473d874a1f9574e56b2ebaabd5b73d1b57d4bab
2017-05-09 21:29:52 +00:00
|
|
|
final class StoryboardViewController: UIViewController, ListAdapterDataSource, StoryboardLabelSectionControllerDelegate {
|
2017-05-16 14:30:08 +00:00
|
|
|
|
2017-03-31 21:45:28 +00:00
|
|
|
@IBOutlet weak var collectionView: UICollectionView!
|
2017-05-16 14:30:08 +00:00
|
|
|
|
Swift name annotations
Summary:
This adds `NS_SWIFT_NAME` annotations to all public API's to provide cleaner integration into Swift:
- Removes the need to prefix classes in Swift code, instead rely on Swift module name spacing
- Adds more argument labels to C function API's like `IGListDiff([], [], .equality)` => `ListDiff(oldArray: [], newArray: [], option: .equality)`
While this is a large API change it should be as easy as:
- Find and replace `(IGList)([^K])` to `List$2` in Xcode with a scope set to Swift
- Build and follow compiler's auto fix corrections for C API's or any missed renames
I have not updated the documentation to reflect this yet, I am totally willing to do so but before I sink that amount of time into it I wanted to see if the Instagram team is even open to this change!
- [x] All tests pass. Demo project builds and runs.
- [x] I added tests, an experiment, or detailed why my change isn't tested.
- [x] I added an entry to the `CHANGELOG.md` for any breaking changes, enhancements, or bug fixes.
- [x] I have reviewed the [contributing guide](https://github.com/Instagram/IGListKit/blob/master/.github/CONTRIBUTING.md)
- [ ] I have updated the documentation
Closes https://github.com/Instagram/IGListKit/pull/593
Reviewed By: jessesquires
Differential Revision: D5028039
Pulled By: rnystrom
fbshipit-source-id: b473d874a1f9574e56b2ebaabd5b73d1b57d4bab
2017-05-09 21:29:52 +00:00
|
|
|
lazy var adapter: ListAdapter = {
|
|
|
|
|
return ListAdapter(updater: ListAdapterUpdater(), viewController: self)
|
2016-10-25 22:17:45 +00:00
|
|
|
}()
|
2017-05-16 14:30:08 +00:00
|
|
|
|
2016-11-21 21:25:52 +00:00
|
|
|
lazy var people = [
|
|
|
|
|
Person(pk: 1, name: "Littlefinger"),
|
|
|
|
|
Person(pk: 2, name: "Tommen Baratheon"),
|
|
|
|
|
Person(pk: 3, name: "Roose Bolton"),
|
|
|
|
|
Person(pk: 4, name: "Brienne of Tarth"),
|
|
|
|
|
Person(pk: 5, name: "Bronn"),
|
|
|
|
|
Person(pk: 6, name: "Gilly"),
|
|
|
|
|
Person(pk: 7, name: "Theon Greyjoy"),
|
|
|
|
|
Person(pk: 8, name: "Jaqen H'ghar"),
|
|
|
|
|
Person(pk: 9, name: "Cersei Lannister"),
|
|
|
|
|
Person(pk: 10, name: "Jaime Lannister"),
|
|
|
|
|
Person(pk: 11, name: "Tyrion Lannister"),
|
|
|
|
|
Person(pk: 12, name: "Melisandre"),
|
|
|
|
|
Person(pk: 13, name: "Missandei"),
|
|
|
|
|
Person(pk: 14, name: "Jorah Mormont"),
|
|
|
|
|
Person(pk: 15, name: "Khal Moro"),
|
|
|
|
|
Person(pk: 16, name: "Daario Naharis"),
|
|
|
|
|
Person(pk: 17, name: "Jon Snow"),
|
|
|
|
|
Person(pk: 18, name: "Arya Stark"),
|
|
|
|
|
Person(pk: 19, name: "Bran Stark"),
|
|
|
|
|
Person(pk: 20, name: "Sansa Stark"),
|
|
|
|
|
Person(pk: 21, name: "Daenerys Targaryen"),
|
|
|
|
|
Person(pk: 22, name: "Samwell Tarly"),
|
|
|
|
|
Person(pk: 23, name: "Tormund"),
|
|
|
|
|
Person(pk: 24, name: "Margaery Tyrell"),
|
|
|
|
|
Person(pk: 25, name: "Varys"),
|
|
|
|
|
Person(pk: 26, name: "Renly Baratheon"),
|
|
|
|
|
Person(pk: 27, name: "Joffrey Baratheon"),
|
|
|
|
|
Person(pk: 28, name: "Stannis Baratheon"),
|
|
|
|
|
Person(pk: 29, name: "Hodor"),
|
|
|
|
|
Person(pk: 30, name: "Tywin Lannister"),
|
|
|
|
|
Person(pk: 31, name: "The Hound"),
|
|
|
|
|
Person(pk: 32, name: "Ramsay Bolton")
|
|
|
|
|
]
|
2017-05-16 14:30:08 +00:00
|
|
|
|
2016-10-25 22:17:45 +00:00
|
|
|
override func viewDidLoad() {
|
|
|
|
|
super.viewDidLoad()
|
|
|
|
|
adapter.collectionView = collectionView
|
|
|
|
|
adapter.dataSource = self
|
|
|
|
|
}
|
2017-05-16 14:30:08 +00:00
|
|
|
|
|
|
|
|
// MARK: ListAdapterDataSource
|
|
|
|
|
|
Swift name annotations
Summary:
This adds `NS_SWIFT_NAME` annotations to all public API's to provide cleaner integration into Swift:
- Removes the need to prefix classes in Swift code, instead rely on Swift module name spacing
- Adds more argument labels to C function API's like `IGListDiff([], [], .equality)` => `ListDiff(oldArray: [], newArray: [], option: .equality)`
While this is a large API change it should be as easy as:
- Find and replace `(IGList)([^K])` to `List$2` in Xcode with a scope set to Swift
- Build and follow compiler's auto fix corrections for C API's or any missed renames
I have not updated the documentation to reflect this yet, I am totally willing to do so but before I sink that amount of time into it I wanted to see if the Instagram team is even open to this change!
- [x] All tests pass. Demo project builds and runs.
- [x] I added tests, an experiment, or detailed why my change isn't tested.
- [x] I added an entry to the `CHANGELOG.md` for any breaking changes, enhancements, or bug fixes.
- [x] I have reviewed the [contributing guide](https://github.com/Instagram/IGListKit/blob/master/.github/CONTRIBUTING.md)
- [ ] I have updated the documentation
Closes https://github.com/Instagram/IGListKit/pull/593
Reviewed By: jessesquires
Differential Revision: D5028039
Pulled By: rnystrom
fbshipit-source-id: b473d874a1f9574e56b2ebaabd5b73d1b57d4bab
2017-05-09 21:29:52 +00:00
|
|
|
func objects(for listAdapter: ListAdapter) -> [ListDiffable] {
|
2016-11-21 21:25:52 +00:00
|
|
|
return people
|
2016-10-25 22:17:45 +00:00
|
|
|
}
|
2017-05-16 14:30:08 +00:00
|
|
|
|
Swift name annotations
Summary:
This adds `NS_SWIFT_NAME` annotations to all public API's to provide cleaner integration into Swift:
- Removes the need to prefix classes in Swift code, instead rely on Swift module name spacing
- Adds more argument labels to C function API's like `IGListDiff([], [], .equality)` => `ListDiff(oldArray: [], newArray: [], option: .equality)`
While this is a large API change it should be as easy as:
- Find and replace `(IGList)([^K])` to `List$2` in Xcode with a scope set to Swift
- Build and follow compiler's auto fix corrections for C API's or any missed renames
I have not updated the documentation to reflect this yet, I am totally willing to do so but before I sink that amount of time into it I wanted to see if the Instagram team is even open to this change!
- [x] All tests pass. Demo project builds and runs.
- [x] I added tests, an experiment, or detailed why my change isn't tested.
- [x] I added an entry to the `CHANGELOG.md` for any breaking changes, enhancements, or bug fixes.
- [x] I have reviewed the [contributing guide](https://github.com/Instagram/IGListKit/blob/master/.github/CONTRIBUTING.md)
- [ ] I have updated the documentation
Closes https://github.com/Instagram/IGListKit/pull/593
Reviewed By: jessesquires
Differential Revision: D5028039
Pulled By: rnystrom
fbshipit-source-id: b473d874a1f9574e56b2ebaabd5b73d1b57d4bab
2017-05-09 21:29:52 +00:00
|
|
|
func listAdapter(_ listAdapter: ListAdapter, sectionControllerFor object: Any) -> ListSectionController {
|
2016-11-21 21:25:52 +00:00
|
|
|
let sectionController = StoryboardLabelSectionController()
|
|
|
|
|
sectionController.delegate = self
|
|
|
|
|
return sectionController
|
2016-10-25 22:17:45 +00:00
|
|
|
}
|
2017-05-16 14:30:08 +00:00
|
|
|
|
Swift name annotations
Summary:
This adds `NS_SWIFT_NAME` annotations to all public API's to provide cleaner integration into Swift:
- Removes the need to prefix classes in Swift code, instead rely on Swift module name spacing
- Adds more argument labels to C function API's like `IGListDiff([], [], .equality)` => `ListDiff(oldArray: [], newArray: [], option: .equality)`
While this is a large API change it should be as easy as:
- Find and replace `(IGList)([^K])` to `List$2` in Xcode with a scope set to Swift
- Build and follow compiler's auto fix corrections for C API's or any missed renames
I have not updated the documentation to reflect this yet, I am totally willing to do so but before I sink that amount of time into it I wanted to see if the Instagram team is even open to this change!
- [x] All tests pass. Demo project builds and runs.
- [x] I added tests, an experiment, or detailed why my change isn't tested.
- [x] I added an entry to the `CHANGELOG.md` for any breaking changes, enhancements, or bug fixes.
- [x] I have reviewed the [contributing guide](https://github.com/Instagram/IGListKit/blob/master/.github/CONTRIBUTING.md)
- [ ] I have updated the documentation
Closes https://github.com/Instagram/IGListKit/pull/593
Reviewed By: jessesquires
Differential Revision: D5028039
Pulled By: rnystrom
fbshipit-source-id: b473d874a1f9574e56b2ebaabd5b73d1b57d4bab
2017-05-09 21:29:52 +00:00
|
|
|
func emptyView(for listAdapter: ListAdapter) -> UIView? { return nil }
|
2017-05-16 14:30:08 +00:00
|
|
|
|
2016-11-21 21:25:52 +00:00
|
|
|
func removeSectionControllerWantsRemoved(_ sectionController: StoryboardLabelSectionController) {
|
|
|
|
|
let section = adapter.section(for: sectionController)
|
|
|
|
|
people.remove(at: Int(section))
|
|
|
|
|
adapter.performUpdates(animated: true)
|
|
|
|
|
}
|
2016-10-25 22:17:45 +00:00
|
|
|
}
|