mirror of
https://github.com/Swiftgram/Telegram-iOS.git
synced 2025-09-03 03:10:47 +00:00
* Add move detection and support to ASLayoutTransition ...and NSArray+Diffing. Add some tests. * Update CHANGELOG.md * Update CHANGELOG.md * Update ASLayout+IGListKit.h * Update ASLayout+IGListKit.mm * Use std collections to avoid NSNumber boxing * Update ASLayoutTransition.mm * Code review updates. * Use `unordered_multimap` on stack instead of unordered_map<id,queue> on heap * Remove notFound BOOL (use NSNotFound sentinel value) and put some vars inside the if (insertions/moves) loop * Don't copy defaultCompare block (redundant under ARC) * Whitespace * Remove unneeded mutableCopy-s in ArrayDiffingTests * Code review updates. * Type _subnodeMoves pair.first to ASDisplayNode * instead of id * C++ enumeration * unowned refs for adding previousLayout nodes to _subnodeMoves * Remove unreleated ASDynamicCast that is probably right though * Add commentary to NSArray+Diffing.h; make multimap elements unowned * Use std::make_pair, optimize ASLayout+IGListKit * Oops I thought I had added these headers but nope * Simplify simplify * Diff subnodes instead of sublayouts * Another randomized test with actual ASLayouts
107 lines
2.9 KiB
Objective-C
107 lines
2.9 KiB
Objective-C
//
|
|
// ASLayoutTransition.h
|
|
// Texture
|
|
//
|
|
// Copyright (c) 2014-present, Facebook, Inc. All rights reserved.
|
|
// This source code is licensed under the BSD-style license found in the
|
|
// LICENSE file in the /ASDK-Licenses directory of this source tree. An additional
|
|
// grant of patent rights can be found in the PATENTS file in the same directory.
|
|
//
|
|
// Modifications to this file made after 4/13/2017 are: Copyright (c) 2017-present,
|
|
// Pinterest, Inc. Licensed under the Apache License, Version 2.0 (the "License");
|
|
// you may not use this file except in compliance with the License.
|
|
// You may obtain a copy of the License at
|
|
//
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
//
|
|
|
|
#import <AsyncDisplayKit/ASDimension.h>
|
|
#import <AsyncDisplayKit/_ASTransitionContext.h>
|
|
#import <AsyncDisplayKit/ASDisplayNodeLayout.h>
|
|
#import <AsyncDisplayKit/ASBaseDefines.h>
|
|
|
|
#import <AsyncDisplayKit/ASDisplayNode.h>
|
|
#import <AsyncDisplayKit/ASLayoutSpec.h>
|
|
|
|
#import <memory>
|
|
|
|
NS_ASSUME_NONNULL_BEGIN
|
|
|
|
#pragma mark - ASLayoutElementTransition
|
|
|
|
/**
|
|
* Objects conform to this project returns if it's possible to layout asynchronous
|
|
*/
|
|
@protocol ASLayoutElementTransition <NSObject>
|
|
|
|
/**
|
|
* @abstract Returns if the layoutElement can be used to layout in an asynchronous way on a background thread.
|
|
*/
|
|
@property (nonatomic, readonly) BOOL canLayoutAsynchronous;
|
|
|
|
@end
|
|
|
|
@interface ASDisplayNode () <ASLayoutElementTransition>
|
|
@end
|
|
@interface ASLayoutSpec () <ASLayoutElementTransition>
|
|
@end
|
|
|
|
|
|
#pragma mark - ASLayoutTransition
|
|
|
|
AS_SUBCLASSING_RESTRICTED
|
|
@interface ASLayoutTransition : NSObject <_ASTransitionContextLayoutDelegate>
|
|
|
|
/**
|
|
* Node to apply layout transition on
|
|
*/
|
|
@property (nonatomic, weak, readonly) ASDisplayNode *node;
|
|
|
|
/**
|
|
* Previous layout to transition from
|
|
*/
|
|
@property (nonatomic, readonly) std::shared_ptr<ASDisplayNodeLayout> previousLayout;
|
|
|
|
/**
|
|
* Pending layout to transition to
|
|
*/
|
|
@property (nonatomic, readonly) std::shared_ptr<ASDisplayNodeLayout> pendingLayout;
|
|
|
|
/**
|
|
* Returns if the layout transition needs to happen synchronously
|
|
*/
|
|
@property (nonatomic, readonly) BOOL isSynchronous;
|
|
|
|
/**
|
|
* Returns a newly initialized layout transition
|
|
*/
|
|
- (instancetype)initWithNode:(ASDisplayNode *)node
|
|
pendingLayout:(std::shared_ptr<ASDisplayNodeLayout>)pendingLayout
|
|
previousLayout:(std::shared_ptr<ASDisplayNodeLayout>)previousLayout NS_DESIGNATED_INITIALIZER;
|
|
|
|
/**
|
|
* Insert and remove subnodes that were added or removed between the previousLayout and the pendingLayout
|
|
*/
|
|
- (void)commitTransition;
|
|
|
|
/**
|
|
* Insert all new subnodes that were added and move the subnodes that moved between the previous layout and
|
|
* the pending layout.
|
|
*/
|
|
- (void)applySubnodeInsertionsAndMoves;
|
|
|
|
/**
|
|
* Remove all subnodes that are removed between the previous layout and the pending layout
|
|
*/
|
|
- (void)applySubnodeRemovals;
|
|
|
|
@end
|
|
|
|
@interface ASLayoutTransition (Unavailable)
|
|
|
|
- (instancetype)init __unavailable;
|
|
|
|
@end
|
|
|
|
NS_ASSUME_NONNULL_END
|