mirror of
https://github.com/Swiftgram/Telegram-iOS.git
synced 2025-12-22 22:25:57 +00:00
[ASViewController] Remeasure node with new constrained size when propagating trait collection (#2143)
This commit is contained in:
@@ -422,6 +422,7 @@
|
|||||||
CC7FD9DF1BB5E962005CCB2B /* ASPhotosFrameworkImageRequest.m in Sources */ = {isa = PBXBuildFile; fileRef = CC7FD9DD1BB5E962005CCB2B /* ASPhotosFrameworkImageRequest.m */; };
|
CC7FD9DF1BB5E962005CCB2B /* ASPhotosFrameworkImageRequest.m in Sources */ = {isa = PBXBuildFile; fileRef = CC7FD9DD1BB5E962005CCB2B /* ASPhotosFrameworkImageRequest.m */; };
|
||||||
CC7FD9E11BB5F750005CCB2B /* ASPhotosFrameworkImageRequestTests.m in Sources */ = {isa = PBXBuildFile; fileRef = CC7FD9E01BB5F750005CCB2B /* ASPhotosFrameworkImageRequestTests.m */; };
|
CC7FD9E11BB5F750005CCB2B /* ASPhotosFrameworkImageRequestTests.m in Sources */ = {isa = PBXBuildFile; fileRef = CC7FD9E01BB5F750005CCB2B /* ASPhotosFrameworkImageRequestTests.m */; };
|
||||||
CC7FD9E21BB603FF005CCB2B /* ASPhotosFrameworkImageRequest.h in Headers */ = {isa = PBXBuildFile; fileRef = CC7FD9DC1BB5E962005CCB2B /* ASPhotosFrameworkImageRequest.h */; settings = {ATTRIBUTES = (Public, ); }; };
|
CC7FD9E21BB603FF005CCB2B /* ASPhotosFrameworkImageRequest.h in Headers */ = {isa = PBXBuildFile; fileRef = CC7FD9DC1BB5E962005CCB2B /* ASPhotosFrameworkImageRequest.h */; settings = {ATTRIBUTES = (Public, ); }; };
|
||||||
|
CCA221D31D6FA7EF00AF6A0F /* ASViewControllerTests.m in Sources */ = {isa = PBXBuildFile; fileRef = CCA221D21D6FA7EF00AF6A0F /* ASViewControllerTests.m */; };
|
||||||
CCB2F34D1D63CCC6004E6DE9 /* ASDisplayNodeSnapshotTests.m in Sources */ = {isa = PBXBuildFile; fileRef = CCB2F34C1D63CCC6004E6DE9 /* ASDisplayNodeSnapshotTests.m */; };
|
CCB2F34D1D63CCC6004E6DE9 /* ASDisplayNodeSnapshotTests.m in Sources */ = {isa = PBXBuildFile; fileRef = CCB2F34C1D63CCC6004E6DE9 /* ASDisplayNodeSnapshotTests.m */; };
|
||||||
CCF18FF41D2575E300DF5895 /* NSIndexSet+ASHelpers.h in Headers */ = {isa = PBXBuildFile; fileRef = CC4981BA1D1C7F65004E13CC /* NSIndexSet+ASHelpers.h */; };
|
CCF18FF41D2575E300DF5895 /* NSIndexSet+ASHelpers.h in Headers */ = {isa = PBXBuildFile; fileRef = CC4981BA1D1C7F65004E13CC /* NSIndexSet+ASHelpers.h */; };
|
||||||
D785F6631A74327E00291744 /* ASScrollNode.m in Sources */ = {isa = PBXBuildFile; fileRef = D785F6611A74327E00291744 /* ASScrollNode.m */; };
|
D785F6631A74327E00291744 /* ASScrollNode.m in Sources */ = {isa = PBXBuildFile; fileRef = D785F6611A74327E00291744 /* ASScrollNode.m */; };
|
||||||
@@ -1092,6 +1093,7 @@
|
|||||||
CC7FD9DC1BB5E962005CCB2B /* ASPhotosFrameworkImageRequest.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = ASPhotosFrameworkImageRequest.h; sourceTree = "<group>"; };
|
CC7FD9DC1BB5E962005CCB2B /* ASPhotosFrameworkImageRequest.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = ASPhotosFrameworkImageRequest.h; sourceTree = "<group>"; };
|
||||||
CC7FD9DD1BB5E962005CCB2B /* ASPhotosFrameworkImageRequest.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = ASPhotosFrameworkImageRequest.m; sourceTree = "<group>"; };
|
CC7FD9DD1BB5E962005CCB2B /* ASPhotosFrameworkImageRequest.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = ASPhotosFrameworkImageRequest.m; sourceTree = "<group>"; };
|
||||||
CC7FD9E01BB5F750005CCB2B /* ASPhotosFrameworkImageRequestTests.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = ASPhotosFrameworkImageRequestTests.m; sourceTree = "<group>"; };
|
CC7FD9E01BB5F750005CCB2B /* ASPhotosFrameworkImageRequestTests.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = ASPhotosFrameworkImageRequestTests.m; sourceTree = "<group>"; };
|
||||||
|
CCA221D21D6FA7EF00AF6A0F /* ASViewControllerTests.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = ASViewControllerTests.m; sourceTree = "<group>"; };
|
||||||
CCB2F34C1D63CCC6004E6DE9 /* ASDisplayNodeSnapshotTests.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = ASDisplayNodeSnapshotTests.m; sourceTree = "<group>"; };
|
CCB2F34C1D63CCC6004E6DE9 /* ASDisplayNodeSnapshotTests.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = ASDisplayNodeSnapshotTests.m; sourceTree = "<group>"; };
|
||||||
D3779BCFF841AD3EB56537ED /* Pods-AsyncDisplayKitTests.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-AsyncDisplayKitTests.release.xcconfig"; path = "Pods/Target Support Files/Pods-AsyncDisplayKitTests/Pods-AsyncDisplayKitTests.release.xcconfig"; sourceTree = "<group>"; };
|
D3779BCFF841AD3EB56537ED /* Pods-AsyncDisplayKitTests.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-AsyncDisplayKitTests.release.xcconfig"; path = "Pods/Target Support Files/Pods-AsyncDisplayKitTests/Pods-AsyncDisplayKitTests.release.xcconfig"; sourceTree = "<group>"; };
|
||||||
D785F6601A74327E00291744 /* ASScrollNode.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = ASScrollNode.h; sourceTree = "<group>"; };
|
D785F6601A74327E00291744 /* ASScrollNode.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = ASScrollNode.h; sourceTree = "<group>"; };
|
||||||
@@ -1326,6 +1328,7 @@
|
|||||||
058D09C5195D04C000B7D73C /* AsyncDisplayKitTests */ = {
|
058D09C5195D04C000B7D73C /* AsyncDisplayKitTests */ = {
|
||||||
isa = PBXGroup;
|
isa = PBXGroup;
|
||||||
children = (
|
children = (
|
||||||
|
CCA221D21D6FA7EF00AF6A0F /* ASViewControllerTests.m */,
|
||||||
CC0AEEA31D66316E005D1C78 /* ASUICollectionViewTests.m */,
|
CC0AEEA31D66316E005D1C78 /* ASUICollectionViewTests.m */,
|
||||||
CCB2F34C1D63CCC6004E6DE9 /* ASDisplayNodeSnapshotTests.m */,
|
CCB2F34C1D63CCC6004E6DE9 /* ASDisplayNodeSnapshotTests.m */,
|
||||||
83A7D95D1D446A6E00BF333E /* ASWeakMapTests.m */,
|
83A7D95D1D446A6E00BF333E /* ASWeakMapTests.m */,
|
||||||
@@ -2184,6 +2187,7 @@
|
|||||||
CC3B208E1C3F7D0A00798563 /* ASWeakSetTests.m in Sources */,
|
CC3B208E1C3F7D0A00798563 /* ASWeakSetTests.m in Sources */,
|
||||||
F711994E1D20C21100568860 /* ASDisplayNodeExtrasTests.m in Sources */,
|
F711994E1D20C21100568860 /* ASDisplayNodeExtrasTests.m in Sources */,
|
||||||
ACF6ED5D1B178DC700DA7C62 /* ASDimensionTests.mm in Sources */,
|
ACF6ED5D1B178DC700DA7C62 /* ASDimensionTests.mm in Sources */,
|
||||||
|
CCA221D31D6FA7EF00AF6A0F /* ASViewControllerTests.m in Sources */,
|
||||||
058D0A38195D057000B7D73C /* ASDisplayLayerTests.m in Sources */,
|
058D0A38195D057000B7D73C /* ASDisplayLayerTests.m in Sources */,
|
||||||
2538B6F31BC5D2A2003CA0B4 /* ASCollectionViewFlowLayoutInspectorTests.m in Sources */,
|
2538B6F31BC5D2A2003CA0B4 /* ASCollectionViewFlowLayoutInspectorTests.m in Sources */,
|
||||||
058D0A39195D057000B7D73C /* ASDisplayNodeAppearanceTests.m in Sources */,
|
058D0A39195D057000B7D73C /* ASDisplayNodeAppearanceTests.m in Sources */,
|
||||||
|
|||||||
@@ -116,7 +116,12 @@ ASVisibilityDidMoveToParentViewController;
|
|||||||
{
|
{
|
||||||
[super viewWillAppear:animated];
|
[super viewWillAppear:animated];
|
||||||
_ensureDisplayed = YES;
|
_ensureDisplayed = YES;
|
||||||
|
|
||||||
|
// We do this early layout because we need to get any ASCollectionNodes etc. into the
|
||||||
|
// hierarchy before UIKit applies the scroll view inset adjustments, if you are using
|
||||||
|
// automatic subnode management.
|
||||||
[_node measureWithSizeRange:[self nodeConstrainedSize]];
|
[_node measureWithSizeRange:[self nodeConstrainedSize]];
|
||||||
|
|
||||||
[_node recursivelyFetchData];
|
[_node recursivelyFetchData];
|
||||||
|
|
||||||
if (_parentManagesVisibilityDepth == NO) {
|
if (_parentManagesVisibilityDepth == NO) {
|
||||||
@@ -295,6 +300,8 @@ ASVisibilityDepthImplementation;
|
|||||||
}
|
}
|
||||||
|
|
||||||
// once we've propagated all the traits, layout this node.
|
// once we've propagated all the traits, layout this node.
|
||||||
|
// Remeasure the node with the latest constrained size – old constrained size may be incorrect.
|
||||||
|
[self.node measureWithSizeRange:[self nodeConstrainedSize]];
|
||||||
[self.node setNeedsLayout];
|
[self.node setNeedsLayout];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
85
AsyncDisplayKitTests/ASViewControllerTests.m
Normal file
85
AsyncDisplayKitTests/ASViewControllerTests.m
Normal file
@@ -0,0 +1,85 @@
|
|||||||
|
//
|
||||||
|
// ASViewControllerTests.m
|
||||||
|
// AsyncDisplayKit
|
||||||
|
//
|
||||||
|
// Created by Adlai Holler on 8/25/16.
|
||||||
|
// Copyright © 2016 Facebook. All rights reserved.
|
||||||
|
//
|
||||||
|
|
||||||
|
#import <XCTest/XCTest.h>
|
||||||
|
#import <AsyncDisplayKit/AsyncDisplayKit.h>
|
||||||
|
#import <OCMock/OCMock.h>
|
||||||
|
|
||||||
|
@interface ASViewControllerTests : XCTestCase
|
||||||
|
|
||||||
|
@end
|
||||||
|
|
||||||
|
@implementation ASViewControllerTests
|
||||||
|
|
||||||
|
- (void)testThatAutomaticSubnodeManagementScrollViewInsetsAreApplied
|
||||||
|
{
|
||||||
|
UIWindow *window = [[UIWindow alloc] initWithFrame:[UIScreen mainScreen].bounds];
|
||||||
|
ASDisplayNode *node = [[ASDisplayNode alloc] init];
|
||||||
|
node.automaticallyManagesSubnodes = YES;
|
||||||
|
ASScrollNode *scrollNode = [[ASScrollNode alloc] init];
|
||||||
|
node.layoutSpecBlock = ^(ASDisplayNode *node, ASSizeRange constrainedSize){
|
||||||
|
return [ASInsetLayoutSpec insetLayoutSpecWithInsets:UIEdgeInsetsZero child:scrollNode];
|
||||||
|
};
|
||||||
|
ASViewController *vc = [[ASViewController alloc] initWithNode:node];
|
||||||
|
window.rootViewController = [[UINavigationController alloc] initWithRootViewController:vc];
|
||||||
|
[window makeKeyAndVisible];
|
||||||
|
[window layoutIfNeeded];
|
||||||
|
XCTAssertEqualObjects(NSStringFromCGRect(window.bounds), NSStringFromCGRect(node.frame));
|
||||||
|
XCTAssertNotEqual(scrollNode.view.contentInset.top, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
- (void)testThatViewControllerFrameIsRightAfterCustomTransitionWithNonextendedEdges
|
||||||
|
{
|
||||||
|
UIWindow *window = [[UIWindow alloc] initWithFrame:[UIScreen mainScreen].bounds];
|
||||||
|
ASDisplayNode *node = [[ASDisplayNode alloc] init];
|
||||||
|
|
||||||
|
ASViewController *vc = [[ASViewController alloc] initWithNode:node];
|
||||||
|
vc.node.backgroundColor = [UIColor greenColor];
|
||||||
|
vc.edgesForExtendedLayout = UIRectEdgeNone;
|
||||||
|
|
||||||
|
UIViewController * oldVC = [[UIViewController alloc] init];
|
||||||
|
UINavigationController *nav = [[UINavigationController alloc] initWithRootViewController:oldVC];
|
||||||
|
id navDelegate = [OCMockObject niceMockForProtocol:@protocol(UINavigationControllerDelegate)];
|
||||||
|
id animator = [OCMockObject niceMockForProtocol:@protocol(UIViewControllerAnimatedTransitioning)];
|
||||||
|
[[[[navDelegate expect] ignoringNonObjectArgs] andReturn:animator] navigationController:[OCMArg any] animationControllerForOperation:UINavigationControllerOperationPush fromViewController:[OCMArg any] toViewController:[OCMArg any]];
|
||||||
|
[[[animator expect] andReturnValue:@0.3] transitionDuration:[OCMArg any]];
|
||||||
|
XCTestExpectation *e = [self expectationWithDescription:@"Transition completed"];
|
||||||
|
[[[animator expect] andDo:^(NSInvocation *invocation) {
|
||||||
|
__unsafe_unretained id<UIViewControllerContextTransitioning> _ctx;
|
||||||
|
[invocation getArgument:&_ctx atIndex:2];
|
||||||
|
__strong id<UIViewControllerContextTransitioning> ctx = _ctx;
|
||||||
|
UIView *container = [ctx containerView];
|
||||||
|
[container addSubview:vc.view];
|
||||||
|
vc.view.alpha = 0;
|
||||||
|
vc.view.frame = [ctx finalFrameForViewController:vc];
|
||||||
|
[UIView animateWithDuration:0.3 animations:^{
|
||||||
|
vc.view.alpha = 1;
|
||||||
|
oldVC.view.alpha = 0;
|
||||||
|
} completion:^(BOOL finished) {
|
||||||
|
[oldVC.view removeFromSuperview];
|
||||||
|
[ctx completeTransition:finished];
|
||||||
|
[e fulfill];
|
||||||
|
}];
|
||||||
|
}] animateTransition:[OCMArg any]];
|
||||||
|
nav.delegate = navDelegate;
|
||||||
|
window.rootViewController = nav;
|
||||||
|
[window makeKeyAndVisible];
|
||||||
|
[[NSRunLoop mainRunLoop] runMode:NSDefaultRunLoopMode beforeDate:[NSDate date]];
|
||||||
|
[nav pushViewController:vc animated:YES];
|
||||||
|
|
||||||
|
[self waitForExpectationsWithTimeout:2 handler:nil];
|
||||||
|
|
||||||
|
CGFloat navHeight = CGRectGetMaxY([nav.navigationBar convertRect:nav.navigationBar.bounds toView:window]);
|
||||||
|
CGRect expectedRect, slice;
|
||||||
|
CGRectDivide(window.bounds, &slice, &expectedRect, navHeight, CGRectMinYEdge);
|
||||||
|
XCTAssertEqualObjects(NSStringFromCGRect(expectedRect), NSStringFromCGRect(node.frame));
|
||||||
|
[navDelegate verify];
|
||||||
|
[animator verify];
|
||||||
|
}
|
||||||
|
|
||||||
|
@end
|
||||||
Reference in New Issue
Block a user