// // ASCollectionNode+Beta.h // Texture // // Copyright (c) Facebook, Inc. and its affiliates. All rights reserved. // Changes after 4/13/2017 are: Copyright (c) Pinterest, Inc. All rights reserved. // Licensed under Apache 2.0: http://www.apache.org/licenses/LICENSE-2.0 // #import @protocol ASCollectionViewLayoutFacilitatorProtocol, ASCollectionLayoutDelegate, ASBatchFetchingDelegate; @class ASElementMap; NS_ASSUME_NONNULL_BEGIN @interface ASCollectionNode (Beta) /** * Allows providing a custom subclass of ASCollectionView to be managed by ASCollectionNode. * * @default [ASCollectionView class] is used whenever this property is unset or nil. */ @property (nullable, nonatomic) Class collectionViewClass; /** * The elements that are currently displayed. The "UIKit index space". Must be accessed on main thread. */ @property (nonatomic, readonly) ASElementMap *visibleElements; @property (nullable, readonly) id layoutDelegate; @property (nullable, nonatomic, weak) id batchFetchingDelegate; /** * When this mode is enabled, ASCollectionView matches the timing of UICollectionView as closely as possible, * ensuring that all reload and edit operations are performed on the main thread as blocking calls. * * This mode is useful for applications that are debugging issues with their collection view implementation. * In particular, some applications do not properly conform to the API requirement of UICollectionView, and these * applications may experience difficulties with ASCollectionView. Providing this mode allows for developers to * work towards resolving technical debt in their collection view data source, while ramping up asynchronous * collection layout. * * NOTE: Because this mode results in expensive operations like cell layout being performed on the main thread, * it should be used as a tool to resolve data source conformance issues with Apple collection view API. * * @default defaults to NO. */ @property (nonatomic) BOOL usesSynchronousDataLoading; /** * Returns YES if the ASCollectionNode contents are completely synchronized with the underlying collection-view layout. */ @property (nonatomic, readonly, getter=isSynchronized) BOOL synchronized; /** * Schedules a block to be performed (on the main thread) as soon as the completion block is called * on performBatchUpdates:. * * When isSynchronized == YES, the block is run block immediately (before the method returns). */ - (void)onDidFinishSynchronizing:(void (^)(void))didFinishSynchronizing; - (instancetype)initWithFrame:(CGRect)frame collectionViewLayout:(UICollectionViewLayout *)layout layoutFacilitator:(nullable id)layoutFacilitator; - (instancetype)initWithLayoutDelegate:(id)layoutDelegate layoutFacilitator:(nullable id)layoutFacilitator; - (void)beginUpdates ASDISPLAYNODE_DEPRECATED_MSG("Use -performBatchUpdates:completion: instead."); - (void)endUpdatesAnimated:(BOOL)animated ASDISPLAYNODE_DEPRECATED_MSG("Use -performBatchUpdates:completion: instead."); - (void)endUpdatesAnimated:(BOOL)animated completion:(nullable void (^)(BOOL))completion ASDISPLAYNODE_DEPRECATED_MSG("Use -performBatchUpdates:completion: instead."); - (void)invalidateFlowLayoutDelegateMetrics; @end NS_ASSUME_NONNULL_END