mirror of
https://github.com/Instagram/IGListKit
synced 2026-05-14 04:49:05 +00:00
Summary: Original comment: If you insert or delete into the same index twice **and** update your data source to reflect those changes, we will squash the insert/delete into a single update because we're using `NSSet` internally. This becomes very apparent when multiple updates are coalesced. Issue fixed: #483 - [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. Closes https://github.com/Instagram/IGListKit/pull/634 Differential Revision: D4860479 Pulled By: jessesquires fbshipit-source-id: 3aa271d90fca21b11201f62cefa8d7fbcef6930f
32 lines
1 KiB
Objective-C
32 lines
1 KiB
Objective-C
/**
|
|
* Copyright (c) 2016-present, Facebook, Inc.
|
|
* All rights reserved.
|
|
*
|
|
* This source code is licensed under the BSD-style license found in the
|
|
* LICENSE file in the root directory of this source tree. An additional grant
|
|
* of patent rights can be found in the PATENTS file in the same directory.
|
|
*/
|
|
|
|
#import "UICollectionView+IGListBatchUpdateData.h"
|
|
|
|
#import "IGListBatchUpdateData.h"
|
|
|
|
@implementation UICollectionView (IGListBatchUpdateData)
|
|
|
|
- (void)ig_applyBatchUpdateData:(IGListBatchUpdateData *)updateData {
|
|
[self deleteItemsAtIndexPaths:updateData.deleteIndexPaths];
|
|
[self insertItemsAtIndexPaths:updateData.insertIndexPaths];
|
|
|
|
for (IGListMoveIndexPath *move in updateData.moveIndexPaths) {
|
|
[self moveItemAtIndexPath:move.from toIndexPath:move.to];
|
|
}
|
|
|
|
for (IGListMoveIndex *move in updateData.moveSections) {
|
|
[self moveSection:move.from toSection:move.to];
|
|
}
|
|
|
|
[self deleteSections:updateData.deleteSections];
|
|
[self insertSections:updateData.insertSections];
|
|
}
|
|
|
|
@end
|