mirror of
https://github.com/Instagram/IGListKit
synced 2026-05-06 15:08:50 +00:00
Summary: Issue fixed: SwiftLint warnings - [x] Operator Usage Whitespace Violation: Operators should be surrounded by a single whitespace when they are being used. (operator_usage_whitespace) - [x] Sorted Imports Violation: Imports should be sorted. (sorted_imports) - [x] Trailing Whitespace Violation: Lines should not have trailing whitespace. (trailing_whitespace) - [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) Pull Request resolved: https://github.com/Instagram/IGListKit/pull/1283 Differential Revision: D13237028 Pulled By: rnystrom fbshipit-source-id: b364f329b0e99ca56704d3d2851cf225759b2a78
101 lines
3.7 KiB
Swift
101 lines
3.7 KiB
Swift
/**
|
|
Copyright (c) Facebook, Inc. and its affiliates.
|
|
|
|
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
|
|
import UIKit
|
|
|
|
final class PrefixedLabelSectionController: ListSectionController, ListSupplementaryViewSource {
|
|
|
|
private var object: LabelsItem?
|
|
|
|
private let prefix: String
|
|
private let group: Int
|
|
|
|
required init(prefix: String, group: Int) {
|
|
self.prefix = prefix
|
|
self.group = group
|
|
super.init()
|
|
self.minimumInteritemSpacing = 1
|
|
self.minimumLineSpacing = 1
|
|
self.supplementaryViewSource = self
|
|
}
|
|
|
|
override func numberOfItems() -> Int {
|
|
guard let object = object else { return 0 }
|
|
return group == 1 ? object.labels1.count : object.labels2.count
|
|
}
|
|
|
|
override func sizeForItem(at index: Int) -> CGSize {
|
|
return CGSize(width: collectionContext!.containerSize.width, height: 55)
|
|
}
|
|
|
|
override func cellForItem(at index: Int) -> UICollectionViewCell {
|
|
guard let cell = collectionContext?.dequeueReusableCell(of: LabelCell.self, for: self, at: index) as? LabelCell else {
|
|
fatalError()
|
|
}
|
|
if let object = object {
|
|
if group == 1 {
|
|
cell.text = "\(prefix) \(object.labels1[index])"
|
|
} else {
|
|
cell.text = "\(prefix) \(object.labels2[index])"
|
|
}
|
|
} else {
|
|
cell.text = "\(prefix) [X]"
|
|
}
|
|
cell.backgroundColor = object?.color
|
|
return cell
|
|
}
|
|
|
|
override func didUpdate(to object: Any) {
|
|
self.object = object as? LabelsItem
|
|
}
|
|
|
|
override func canMoveItem(at index: Int) -> Bool {
|
|
return true
|
|
}
|
|
|
|
override func moveObject(from sourceIndex: Int, to destinationIndex: Int) {
|
|
guard let object = object else { return }
|
|
if group == 1 {
|
|
let item = object.labels1.remove(at: sourceIndex)
|
|
object.labels1.insert(item, at: destinationIndex)
|
|
} else {
|
|
let item = object.labels2.remove(at: sourceIndex)
|
|
object.labels2.insert(item, at: destinationIndex)
|
|
}
|
|
}
|
|
|
|
// MARK: ListSupplementaryViewSource
|
|
|
|
func supportedElementKinds() -> [String] {
|
|
return [UICollectionElementKindSectionHeader]
|
|
}
|
|
|
|
func viewForSupplementaryElement(ofKind elementKind: String, at index: Int) -> UICollectionReusableView {
|
|
guard let view = collectionContext?.dequeueReusableSupplementaryView(ofKind: UICollectionElementKindSectionHeader,
|
|
for: self,
|
|
nibName: "UserHeaderView",
|
|
bundle: nil,
|
|
at: index) as? UserHeaderView else {
|
|
fatalError()
|
|
}
|
|
view.name = "Sections of Letters & Numbers"
|
|
view.handle = ""
|
|
return view
|
|
}
|
|
|
|
func sizeForSupplementaryView(ofKind elementKind: String, at index: Int) -> CGSize {
|
|
return CGSize(width: collectionContext!.containerSize.width, height: 40)
|
|
}
|
|
}
|