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-26 18:47:10 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
import IGListKit
|
2018-01-22 20:01:53 +00:00
|
|
|
import UIKit
|
2016-10-26 18:47:10 +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 Person: ListDiffable {
|
2016-10-26 18:47:10 +00:00
|
|
|
|
|
|
|
|
let pk: Int
|
|
|
|
|
let name: String
|
|
|
|
|
|
|
|
|
|
init(pk: Int, name: String) {
|
|
|
|
|
self.pk = pk
|
|
|
|
|
self.name = name
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func diffIdentifier() -> NSObjectProtocol {
|
|
|
|
|
return pk as NSNumber
|
|
|
|
|
}
|
|
|
|
|
|
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 isEqual(toDiffableObject object: ListDiffable?) -> Bool {
|
2016-11-02 21:10:09 +00:00
|
|
|
guard let object = object as? Person else { return false }
|
|
|
|
|
return self.name == object.name
|
2016-10-26 18:47:10 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
2016-11-07 23:53:31 +00:00
|
|
|
final class DiffTableViewController: UITableViewController {
|
2016-10-26 18:47:10 +00:00
|
|
|
|
|
|
|
|
let oldPeople = [
|
|
|
|
|
Person(pk: 1, name: "Kevin"),
|
|
|
|
|
Person(pk: 2, name: "Mike"),
|
|
|
|
|
Person(pk: 3, name: "Ann"),
|
|
|
|
|
Person(pk: 4, name: "Jane"),
|
|
|
|
|
Person(pk: 5, name: "Philip"),
|
|
|
|
|
Person(pk: 6, name: "Mona"),
|
|
|
|
|
Person(pk: 7, name: "Tami"),
|
|
|
|
|
Person(pk: 8, name: "Jesse"),
|
|
|
|
|
Person(pk: 9, name: "Jaed")
|
|
|
|
|
]
|
|
|
|
|
let newPeople = [
|
|
|
|
|
Person(pk: 2, name: "Mike"),
|
|
|
|
|
Person(pk: 10, name: "Marne"),
|
|
|
|
|
Person(pk: 5, name: "Philip"),
|
|
|
|
|
Person(pk: 1, name: "Kevin"),
|
|
|
|
|
Person(pk: 3, name: "Ryan"),
|
|
|
|
|
Person(pk: 8, name: "Jesse"),
|
|
|
|
|
Person(pk: 7, name: "Tami"),
|
|
|
|
|
Person(pk: 4, name: "Jane"),
|
|
|
|
|
Person(pk: 9, name: "Chen")
|
|
|
|
|
]
|
|
|
|
|
lazy var people: [Person] = {
|
|
|
|
|
return self.oldPeople
|
|
|
|
|
}()
|
|
|
|
|
var usingOldPeople = true
|
|
|
|
|
|
|
|
|
|
override func viewDidLoad() {
|
|
|
|
|
super.viewDidLoad()
|
|
|
|
|
navigationItem.rightBarButtonItem = UIBarButtonItem(barButtonSystemItem: .play,
|
|
|
|
|
target: self,
|
|
|
|
|
action: #selector(DiffTableViewController.onDiff))
|
|
|
|
|
tableView.register(UITableViewCell.self, forCellReuseIdentifier: "cell")
|
|
|
|
|
}
|
|
|
|
|
|
2017-09-22 13:34:52 +00:00
|
|
|
@objc func onDiff() {
|
2016-10-26 18:47:10 +00:00
|
|
|
let from = people
|
|
|
|
|
let to = usingOldPeople ? newPeople : oldPeople
|
|
|
|
|
usingOldPeople = !usingOldPeople
|
|
|
|
|
people = to
|
|
|
|
|
|
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
|
|
|
let result = ListDiffPaths(fromSection: 0, toSection: 0, oldArray: from, newArray: to, option: .equality).forBatchUpdates()
|
2016-10-26 18:47:10 +00:00
|
|
|
|
|
|
|
|
tableView.beginUpdates()
|
|
|
|
|
tableView.deleteRows(at: result.deletes, with: .fade)
|
|
|
|
|
tableView.insertRows(at: result.inserts, with: .fade)
|
2016-11-09 17:15:46 +00:00
|
|
|
result.moves.forEach { tableView.moveRow(at: $0.from, to: $0.to) }
|
2016-10-26 18:47:10 +00:00
|
|
|
tableView.endUpdates()
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// MARK: UITableViewDataSource
|
|
|
|
|
|
|
|
|
|
override func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
|
|
|
|
|
return people.count
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
|
|
|
|
|
let cell = tableView.dequeueReusableCell(withIdentifier: "cell", for: indexPath)
|
|
|
|
|
cell.textLabel?.text = people[indexPath.row].name
|
|
|
|
|
return cell
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|