[
https://issues.apache.org/jira/browse/WEEX-657?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=16698578#comment-16698578
]
ASF GitHub Bot commented on WEEX-657:
-------------------------------------
blackteachinese closed pull request #1731: [WEEX-657][iOS] Add a feature to
control the offset of list attach to…
URL: https://github.com/apache/incubator-weex/pull/1731
This is a PR merged from a forked repository.
As GitHub hides the original diff on merge, it is displayed below for
the sake of provenance:
As this is a foreign pull request (from a fork), the diff is supplied
below (as it won't show otherwise due to GitHub magic):
diff --git a/ios/sdk/WeexSDK.xcodeproj/project.pbxproj
b/ios/sdk/WeexSDK.xcodeproj/project.pbxproj
index d6aca1de3f..af73a07fb9 100644
--- a/ios/sdk/WeexSDK.xcodeproj/project.pbxproj
+++ b/ios/sdk/WeexSDK.xcodeproj/project.pbxproj
@@ -1033,6 +1033,7 @@
DCF0CD9E1EAF3A6B0062CA8F /* native-bundle-main.js in Resources
*/ = {isa = PBXBuildFile; fileRef = DCF0CD9D1EAF3A6B0062CA8F /*
native-bundle-main.js */; };
DCF343671E49CAEE00A2FB34 /* WXJSExceptionInfo.h in Headers */ =
{isa = PBXBuildFile; fileRef = DCF343651E49CAEE00A2FB34 /* WXJSExceptionInfo.h
*/; settings = {ATTRIBUTES = (Public, ); }; };
DCF343681E49CAEE00A2FB34 /* WXJSExceptionInfo.m in Sources */ =
{isa = PBXBuildFile; fileRef = DCF343661E49CAEE00A2FB34 /* WXJSExceptionInfo.m
*/; };
+ E6F9D95421A80E780082072E /* WXListComponent_internal.h in
Headers */ = {isa = PBXBuildFile; fileRef = E6F9D95321A80E780082072E /*
WXListComponent_internal.h */; };
ED053500207F4DEB007B4568 /* JSContext+Weex.h in Headers */ =
{isa = PBXBuildFile; fileRef = ED0534FE207F4DEB007B4568 /* JSContext+Weex.h */;
settings = {ATTRIBUTES = (Public, ); }; };
ED053501207F4DEB007B4568 /* JSContext+Weex.h in Headers */ =
{isa = PBXBuildFile; fileRef = ED0534FE207F4DEB007B4568 /* JSContext+Weex.h */;
settings = {ATTRIBUTES = (Public, ); }; };
ED053502207F4DEB007B4568 /* JSContext+Weex.m in Sources */ =
{isa = PBXBuildFile; fileRef = ED0534FF207F4DEB007B4568 /* JSContext+Weex.m */;
};
@@ -1602,6 +1603,7 @@
DCF0CD9D1EAF3A6B0062CA8F /* native-bundle-main.js */ = {isa =
PBXFileReference; lastKnownFileType = sourcecode.javascript; name =
"native-bundle-main.js"; path = "../../../../pre-build/native-bundle-main.js";
sourceTree = "<group>"; };
DCF343651E49CAEE00A2FB34 /* WXJSExceptionInfo.h */ = {isa =
PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path =
WXJSExceptionInfo.h; sourceTree = "<group>"; };
DCF343661E49CAEE00A2FB34 /* WXJSExceptionInfo.m */ = {isa =
PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path
= WXJSExceptionInfo.m; sourceTree = "<group>"; };
+ E6F9D95321A80E780082072E /* WXListComponent_internal.h */ =
{isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path =
WXListComponent_internal.h; sourceTree = "<group>"; };
ED0534FE207F4DEB007B4568 /* JSContext+Weex.h */ = {isa =
PBXFileReference; lastKnownFileType = sourcecode.c.h; path =
"JSContext+Weex.h"; sourceTree = "<group>"; };
ED0534FF207F4DEB007B4568 /* JSContext+Weex.m */ = {isa =
PBXFileReference; lastKnownFileType = sourcecode.c.objc; path =
"JSContext+Weex.m"; sourceTree = "<group>"; };
/* End PBXFileReference section */
@@ -2197,6 +2199,7 @@
37B51EE31E97804D0040A743 /*
WXCycleSliderComponent.mm */,
74CC7A1B1C2BC5F800829368 /* WXCellComponent.mm
*/,
74CC7A1E1C2BF9DC00829368 /* WXListComponent.h
*/,
+ E6F9D95321A80E780082072E /*
WXListComponent_internal.h */,
74CC7A1F1C2BF9DC00829368 /* WXListComponent.mm
*/,
2AC750221C7565690041D390 /*
WXIndicatorComponent.h */,
2AC750231C7565690041D390 /*
WXIndicatorComponent.m */,
diff --git a/ios/sdk/WeexSDK/Sources/Component/WXListComponent.mm
b/ios/sdk/WeexSDK/Sources/Component/WXListComponent.mm
index a9f18bf1b1..b63231411a 100644
--- a/ios/sdk/WeexSDK/Sources/Component/WXListComponent.mm
+++ b/ios/sdk/WeexSDK/Sources/Component/WXListComponent.mm
@@ -32,6 +32,14 @@
#import "WXRefreshComponent.h"
#import "WXLoadingComponent.h"
+@interface WXListComponent () <UITableViewDataSource, UITableViewDelegate,
WXCellRenderDelegate, WXHeaderRenderDelegate>
+
+@property (nonatomic, assign) NSUInteger currentTopVisibleSection;
+// Set whether the content offset position all the way to the bottom
+@property (assign, nonatomic) BOOL contentAttachBottom;
+
+@end
+
@interface WXTableView : UITableView
@end
@@ -79,6 +87,19 @@ - (void)setContentOffset:(CGPoint)contentOffset
[super setContentOffset:contentOffset];
}
+- (void)setFrame:(CGRect)frame {
+ [super setFrame:frame];
+ if (![self.wx_component isKindOfClass:[WXListComponent class]]) return;
+ BOOL contentAttachBottom = [(WXListComponent *)self.wx_component
contentAttachBottom];
+ if (contentAttachBottom) {
+ CGFloat offsetHeight = self.contentSize.height -
CGRectGetHeight(self.bounds);
+ if (offsetHeight >= 0) {
+ [self setContentOffset:CGPointMake(0, offsetHeight) animated:NO];
+ }
+ }
+}
+
+
@end
// WXText is a non-public is not permitted
@@ -114,12 +135,6 @@ - (NSString *)description
}
@end
-@interface WXListComponent () <UITableViewDataSource, UITableViewDelegate,
WXCellRenderDelegate, WXHeaderRenderDelegate>
-
-@property (nonatomic, assign) NSUInteger currentTopVisibleSection;
-
-@end
-
@implementation WXListComponent
{
__weak UITableView * _tableView;
@@ -144,6 +159,7 @@ - (instancetype)initWithRef:(NSString *)ref type:(NSString
*)type styles:(NSDict
_completedSections = [NSMutableArray array];
_reloadInterval = attributes[@"reloadInterval"] ? [WXConvert
CGFloat:attributes[@"reloadInterval"]]/1000 : 0;
_updataType = [WXConvert
NSString:attributes[@"updataType"]]?:@"insert";
+ _contentAttachBottom = [WXConvert
BOOL:attributes[@"contentAttachBottom"]];
[self fixFlicker];
}
@@ -198,6 +214,9 @@ - (void)updateAttributes:(NSDictionary *)attributes
if (attributes[@"updataType"]) {
_updataType = [WXConvert NSString:attributes[@"updataType"]];
}
+ if (attributes[@"contentAttachBottom"]) {
+ _contentAttachBottom = [WXConvert
BOOL:attributes[@"contentAttachBottom"]];
+ }
}
- (void)setContentSize:(CGSize)contentSize
----------------------------------------------------------------
This is an automated message from the Apache Git Service.
To respond to the message, please log on GitHub and use the
URL above to go to the specific comment.
For queries about this service, please contact Infrastructure at:
[email protected]
> When the List component is shortened for Transition animation, the content
> offset position of the List needs to be fixed at the bottom.
> ---------------------------------------------------------------------------------------------------------------------------------------
>
> Key: WEEX-657
> URL: https://issues.apache.org/jira/browse/WEEX-657
> Project: Weex
> Issue Type: Improvement
> Components: iOS
> Affects Versions: 0.19
> Environment: iOS
> Reporter: hongwei
> Assignee: XuYouyang
> Priority: Major
> Labels: ready-to-commit
> Fix For: 0.19
>
> Original Estimate: 48h
> Remaining Estimate: 48h
>
> We have a message list business scenario, the List component will set the
> length of the Height change in the Transition animation. At this time, the
> content offset of the List needs to be kept at the bottom. The List component
> does not currently have this capability.
--
This message was sent by Atlassian JIRA
(v7.6.3#76005)