2016-11-07 14:37:37 +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
|
|
|
|
|
|
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 FeedItemSectionController: ListSectionController, ListSupplementaryViewSource {
|
2016-11-07 14:37:37 +00:00
|
|
|
|
2017-04-11 20:20:56 +00:00
|
|
|
private var feedItem: FeedItem!
|
2016-11-07 14:37:37 +00:00
|
|
|
|
|
|
|
|
override init() {
|
|
|
|
|
super.init()
|
|
|
|
|
supplementaryViewSource = self
|
|
|
|
|
}
|
|
|
|
|
|
2017-04-19 15:17:56 +00:00
|
|
|
// MARK: IGListSectionController Overrides
|
2016-11-07 14:37:37 +00:00
|
|
|
|
2017-04-19 15:17:56 +00:00
|
|
|
override func numberOfItems() -> Int {
|
2016-11-07 14:37:37 +00:00
|
|
|
return feedItem.comments.count
|
|
|
|
|
}
|
|
|
|
|
|
2017-04-19 15:17:56 +00:00
|
|
|
override func sizeForItem(at index: Int) -> CGSize {
|
2016-11-07 14:37:37 +00:00
|
|
|
return CGSize(width: collectionContext!.containerSize.width, height: 55)
|
|
|
|
|
}
|
|
|
|
|
|
2017-04-19 15:17:56 +00:00
|
|
|
override func cellForItem(at index: Int) -> UICollectionViewCell {
|
2017-05-16 14:30:08 +00:00
|
|
|
guard let cell = collectionContext?.dequeueReusableCell(of: LabelCell.self, for: self, at: index) as? LabelCell else {
|
|
|
|
|
fatalError()
|
|
|
|
|
}
|
2017-04-11 20:20:56 +00:00
|
|
|
cell.text = feedItem.comments[index]
|
2016-11-07 14:37:37 +00:00
|
|
|
return cell
|
|
|
|
|
}
|
|
|
|
|
|
2017-04-19 15:17:56 +00:00
|
|
|
override func didUpdate(to object: Any) {
|
2016-11-07 14:37:37 +00:00
|
|
|
feedItem = object as? FeedItem
|
|
|
|
|
}
|
|
|
|
|
|
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
|
|
|
// MARK: ListSupplementaryViewSource
|
2016-11-07 14:37:37 +00:00
|
|
|
|
|
|
|
|
func supportedElementKinds() -> [String] {
|
2017-11-21 20:39:09 +00:00
|
|
|
return [UICollectionElementKindSectionHeader, UICollectionElementKindSectionFooter]
|
2016-11-07 14:37:37 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func viewForSupplementaryElement(ofKind elementKind: String, at index: Int) -> UICollectionReusableView {
|
2017-11-21 20:39:09 +00:00
|
|
|
switch elementKind {
|
|
|
|
|
case UICollectionElementKindSectionHeader:
|
|
|
|
|
return userHeaderView(atIndex: index)
|
|
|
|
|
case UICollectionElementKindSectionFooter:
|
|
|
|
|
return userFooterView(atIndex: index)
|
|
|
|
|
default:
|
|
|
|
|
fatalError()
|
2017-05-16 14:30:08 +00:00
|
|
|
}
|
2016-11-07 14:37:37 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func sizeForSupplementaryView(ofKind elementKind: String, at index: Int) -> CGSize {
|
|
|
|
|
return CGSize(width: collectionContext!.containerSize.width, height: 40)
|
|
|
|
|
}
|
|
|
|
|
|
2017-11-21 20:39:09 +00:00
|
|
|
// MARK: Private
|
|
|
|
|
private func userHeaderView(atIndex index: Int) -> UICollectionReusableView {
|
|
|
|
|
guard let view = collectionContext?.dequeueReusableSupplementaryView(ofKind: UICollectionElementKindSectionHeader,
|
|
|
|
|
for: self,
|
|
|
|
|
nibName: "UserHeaderView",
|
|
|
|
|
bundle: nil,
|
|
|
|
|
at: index) as? UserHeaderView else {
|
|
|
|
|
fatalError()
|
|
|
|
|
}
|
|
|
|
|
view.handle = "@" + feedItem.user.handle
|
|
|
|
|
view.name = feedItem.user.name
|
|
|
|
|
return view
|
|
|
|
|
}
|
2017-12-19 17:23:37 +00:00
|
|
|
|
2017-11-21 20:39:09 +00:00
|
|
|
private func userFooterView(atIndex index: Int) -> UICollectionReusableView {
|
|
|
|
|
guard let view = collectionContext?.dequeueReusableSupplementaryView(ofKind: UICollectionElementKindSectionFooter,
|
|
|
|
|
for: self,
|
|
|
|
|
nibName: "UserFooterView",
|
|
|
|
|
bundle: nil,
|
|
|
|
|
at: index) as? UserFooterView else {
|
|
|
|
|
fatalError()
|
|
|
|
|
}
|
2017-12-19 17:23:37 +00:00
|
|
|
|
2017-11-21 20:39:09 +00:00
|
|
|
view.commentsCount = "\(feedItem.comments.count)"
|
|
|
|
|
return view
|
|
|
|
|
}
|
2016-11-07 14:37:37 +00:00
|
|
|
}
|