2015-03-23 20:28:42 +00:00
|
|
|
/**
|
|
|
|
* Copyright (c) 2015-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.
|
|
|
|
*/
|
2015-02-20 04:10:52 +00:00
|
|
|
|
|
|
|
#import <UIKit/UIScrollView.h>
|
|
|
|
|
|
|
|
#import "RCTAutoInsetsProtocol.h"
|
2015-05-28 03:15:33 +00:00
|
|
|
#import "RCTEventDispatcher.h"
|
2015-02-20 04:10:52 +00:00
|
|
|
#import "RCTScrollableProtocol.h"
|
|
|
|
#import "RCTView.h"
|
|
|
|
|
|
|
|
@protocol UIScrollViewDelegate;
|
|
|
|
|
|
|
|
@interface RCTScrollView : RCTView <UIScrollViewDelegate, RCTScrollableProtocol, RCTAutoInsetsProtocol>
|
|
|
|
|
2015-03-01 23:33:55 +00:00
|
|
|
- (instancetype)initWithEventDispatcher:(RCTEventDispatcher *)eventDispatcher NS_DESIGNATED_INITIALIZER;
|
|
|
|
|
2015-02-20 04:10:52 +00:00
|
|
|
/**
|
|
|
|
* The `RCTScrollView` may have at most one single subview. This will ensure
|
|
|
|
* that the scroll view's `contentSize` will be efficiently set to the size of
|
|
|
|
* the single subview's frame. That frame size will be determined somewhat
|
|
|
|
* efficiently since it will have already been computed by the off-main-thread
|
|
|
|
* layout system.
|
|
|
|
*/
|
|
|
|
@property (nonatomic, readonly) UIView *contentView;
|
|
|
|
|
2015-03-25 22:01:00 +00:00
|
|
|
/**
|
|
|
|
* If the `contentSize` is not specified (or is specified as {0, 0}, then the
|
|
|
|
* `contentSize` will automatically be determined by the size of the subview.
|
|
|
|
*/
|
2015-02-20 04:10:52 +00:00
|
|
|
@property (nonatomic, assign) CGSize contentSize;
|
2015-03-25 22:01:00 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The underlying scrollView (TODO: can we remove this?)
|
|
|
|
*/
|
|
|
|
@property (nonatomic, readonly) UIScrollView *scrollView;
|
|
|
|
|
2015-02-20 04:10:52 +00:00
|
|
|
@property (nonatomic, assign) UIEdgeInsets contentInset;
|
|
|
|
@property (nonatomic, assign) BOOL automaticallyAdjustContentInsets;
|
2015-03-30 11:58:02 +00:00
|
|
|
@property (nonatomic, assign) NSTimeInterval scrollEventThrottle;
|
2015-02-20 04:10:52 +00:00
|
|
|
@property (nonatomic, assign) BOOL centerContent;
|
2015-09-23 18:43:57 +00:00
|
|
|
@property (nonatomic, assign) int snapToInterval;
|
|
|
|
@property (nonatomic, copy) NSString *snapToAlignment;
|
2015-05-06 17:46:45 +00:00
|
|
|
@property (nonatomic, copy) NSIndexSet *stickyHeaderIndices;
|
2015-11-19 19:13:42 +00:00
|
|
|
@property (nonatomic, copy) RCTDirectEventBlock onRefreshStart;
|
|
|
|
|
|
|
|
- (void)endRefreshing;
|
2015-02-20 04:10:52 +00:00
|
|
|
|
|
|
|
@end
|
2015-05-28 03:15:33 +00:00
|
|
|
|
|
|
|
@interface RCTEventDispatcher (RCTScrollView)
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Send a scroll event.
|
|
|
|
* (You can send a fake scroll event by passing nil for scrollView).
|
|
|
|
*/
|
|
|
|
- (void)sendScrollEventWithType:(RCTScrollEventType)type
|
|
|
|
reactTag:(NSNumber *)reactTag
|
|
|
|
scrollView:(UIScrollView *)scrollView
|
|
|
|
userData:(NSDictionary *)userData;
|
|
|
|
|
|
|
|
@end
|