2019-12-19 17:32:49 +00:00
|
|
|
/*
|
2023-04-06 09:44:16 +00:00
|
|
|
* Copyright (c) Meta Platforms, Inc. and affiliates.
|
2019-12-19 17:32:49 +00:00
|
|
|
*
|
|
|
|
|
* This source code is licensed under the MIT license found in the
|
|
|
|
|
* LICENSE file in the root directory of this source tree.
|
2016-10-20 06:26:07 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
import IGListKit
|
2018-01-22 20:01:53 +00:00
|
|
|
import UIKit
|
2016-10-20 06:26:07 +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 WorkingRangeSectionController: ListSectionController, ListWorkingRangeDelegate {
|
2016-10-20 06:26:07 +00:00
|
|
|
|
2017-04-11 20:20:56 +00:00
|
|
|
private var height: Int?
|
|
|
|
|
private var downloadedImage: UIImage?
|
|
|
|
|
private var task: URLSessionDataTask?
|
2016-10-20 06:26:07 +00:00
|
|
|
|
2017-04-11 20:20:56 +00:00
|
|
|
private var urlString: String? {
|
2016-10-20 06:26:07 +00:00
|
|
|
guard let height = height,
|
2019-11-20 19:33:55 +00:00
|
|
|
let size = collectionContext?.containerSize
|
2016-10-20 06:26:07 +00:00
|
|
|
else { return nil }
|
2019-11-20 19:33:55 +00:00
|
|
|
let width = Int(size.width)
|
2016-10-20 06:26:07 +00:00
|
|
|
return "https://unsplash.it/" + width.description + "/" + height.description
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
deinit {
|
|
|
|
|
task?.cancel()
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
override init() {
|
|
|
|
|
super.init()
|
|
|
|
|
workingRangeDelegate = self
|
|
|
|
|
}
|
|
|
|
|
|
2017-04-19 15:17:56 +00:00
|
|
|
override func numberOfItems() -> Int {
|
2016-10-20 06:26:07 +00:00
|
|
|
return 2
|
|
|
|
|
}
|
|
|
|
|
|
2017-04-19 15:17:56 +00:00
|
|
|
override func sizeForItem(at index: Int) -> CGSize {
|
2016-10-20 06:26:07 +00:00
|
|
|
let width: CGFloat = collectionContext?.containerSize.width ?? 0
|
|
|
|
|
let height: CGFloat = CGFloat(index == 0 ? 55 : (self.height ?? 0))
|
|
|
|
|
return CGSize(width: width, height: height)
|
|
|
|
|
}
|
|
|
|
|
|
2017-04-19 15:17:56 +00:00
|
|
|
override func cellForItem(at index: Int) -> UICollectionViewCell {
|
2019-12-19 16:11:46 +00:00
|
|
|
let cellClass: UICollectionViewCell.Type = index == 0 ? LabelCell.self : ImageCell.self
|
2021-02-05 17:34:26 +00:00
|
|
|
let cell = collectionContext.dequeueReusableCell(of: cellClass, for: self, at: index)
|
2016-10-20 06:26:07 +00:00
|
|
|
if let cell = cell as? LabelCell {
|
2017-04-11 20:20:56 +00:00
|
|
|
cell.text = urlString
|
2016-10-20 06:26:07 +00:00
|
|
|
} else if let cell = cell as? ImageCell {
|
|
|
|
|
cell.setImage(image: downloadedImage)
|
|
|
|
|
}
|
|
|
|
|
return cell
|
|
|
|
|
}
|
|
|
|
|
|
2017-04-19 15:17:56 +00:00
|
|
|
override func didUpdate(to object: Any) {
|
2016-10-20 06:26:07 +00:00
|
|
|
self.height = object as? Int
|
|
|
|
|
}
|
|
|
|
|
|
2017-05-16 14:30:08 +00:00
|
|
|
// MARK: ListWorkingRangeDelegate
|
2016-10-20 06:26:07 +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, sectionControllerWillEnterWorkingRange sectionController: ListSectionController) {
|
2016-10-20 06:26:07 +00:00
|
|
|
guard downloadedImage == nil,
|
|
|
|
|
task == nil,
|
|
|
|
|
let urlString = urlString,
|
|
|
|
|
let url = URL(string: urlString)
|
|
|
|
|
else { return }
|
|
|
|
|
|
2017-05-11 21:46:22 +00:00
|
|
|
print("Downloading image \(urlString) for section \(self.section)")
|
2016-10-20 06:26:07 +00:00
|
|
|
|
2017-05-16 14:30:08 +00:00
|
|
|
task = URLSession.shared.dataTask(with: url) { data, _, error in
|
2016-10-27 16:38:27 +00:00
|
|
|
guard let data = data, let image = UIImage(data: data) else {
|
2017-05-16 14:30:08 +00:00
|
|
|
return print("Error downloading \(urlString): " + String(describing: error))
|
2016-10-27 16:38:27 +00:00
|
|
|
}
|
|
|
|
|
DispatchQueue.main.async {
|
|
|
|
|
self.downloadedImage = image
|
|
|
|
|
if let cell = self.collectionContext?.cellForItem(at: 1, sectionController: self) as? ImageCell {
|
|
|
|
|
cell.setImage(image: image)
|
2016-10-20 06:26:07 +00:00
|
|
|
}
|
|
|
|
|
}
|
2016-10-27 16:38:27 +00:00
|
|
|
}
|
2016-10-20 06:26:07 +00:00
|
|
|
task?.resume()
|
|
|
|
|
}
|
|
|
|
|
|
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, sectionControllerDidExitWorkingRange sectionController: ListSectionController) {}
|
2016-10-20 06:26:07 +00:00
|
|
|
|
|
|
|
|
}
|