mirror of
https://github.com/status-im/react-native.git
synced 2025-01-19 05:51:01 +00:00
75284d3cd4
Summary: **Motivation** Properly support long presses on the Apple TV remote, and also enable dev menu functionality on a real Apple TV device (shaking an Apple TV doesn't work 😄 ) **Test plan** New example added to `RNTester`. Closes https://github.com/facebook/react-native/pull/15221 Differential Revision: D5526463 Pulled By: javache fbshipit-source-id: a61051e86bc82a9561eefc1704bed6b1f2617e05
116 lines
2.8 KiB
Objective-C
116 lines
2.8 KiB
Objective-C
/**
|
|
* 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.
|
|
*/
|
|
|
|
#import <UIKit/UIKit.h>
|
|
|
|
#import <React/RCTBridge.h>
|
|
#import <React/RCTBridgeModule.h>
|
|
|
|
#if RCT_DEV
|
|
|
|
RCT_EXTERN NSString *const RCTShowDevMenuNotification;
|
|
|
|
#endif
|
|
|
|
|
|
@class RCTDevMenuItem;
|
|
|
|
/**
|
|
* Developer menu, useful for exposing extra functionality when debugging.
|
|
*/
|
|
@interface RCTDevMenu : NSObject
|
|
|
|
/**
|
|
* Deprecated, use RCTDevSettings instead.
|
|
*/
|
|
@property (nonatomic, assign) BOOL shakeToShow DEPRECATED_ATTRIBUTE;
|
|
|
|
/**
|
|
* Deprecated, use RCTDevSettings instead.
|
|
*/
|
|
@property (nonatomic, assign) BOOL profilingEnabled DEPRECATED_ATTRIBUTE;
|
|
|
|
/**
|
|
* Deprecated, use RCTDevSettings instead.
|
|
*/
|
|
@property (nonatomic, assign) BOOL liveReloadEnabled DEPRECATED_ATTRIBUTE;
|
|
|
|
/**
|
|
* Deprecated, use RCTDevSettings instead.
|
|
*/
|
|
@property (nonatomic, assign) BOOL hotLoadingEnabled DEPRECATED_ATTRIBUTE;
|
|
|
|
/**
|
|
* Presented items in development menu
|
|
*/
|
|
@property (nonatomic, copy, readonly) NSArray<RCTDevMenuItem *> *presentedItems;
|
|
|
|
/**
|
|
* Detect if actions sheet (development menu) is shown
|
|
*/
|
|
- (BOOL)isActionSheetShown;
|
|
|
|
/**
|
|
* Manually show the dev menu (can be called from JS).
|
|
*/
|
|
- (void)show;
|
|
|
|
/**
|
|
* Deprecated, use -[RCTBRidge reload] instead.
|
|
*/
|
|
- (void)reload DEPRECATED_ATTRIBUTE;
|
|
|
|
/**
|
|
* Deprecated. Use the `-addItem:` method instead.
|
|
*/
|
|
- (void)addItem:(NSString *)title
|
|
handler:(void(^)(void))handler DEPRECATED_ATTRIBUTE;
|
|
|
|
/**
|
|
* Add custom item to the development menu. The handler will be called
|
|
* when user selects the item.
|
|
*/
|
|
- (void)addItem:(RCTDevMenuItem *)item;
|
|
|
|
@end
|
|
|
|
typedef NSString *(^RCTDevMenuItemTitleBlock)(void);
|
|
|
|
/**
|
|
* Developer menu item, used to expose additional functionality via the menu.
|
|
*/
|
|
@interface RCTDevMenuItem : NSObject
|
|
|
|
/**
|
|
* This creates an item with a simple push-button interface, used to trigger an
|
|
* action.
|
|
*/
|
|
+ (instancetype)buttonItemWithTitle:(NSString *)title
|
|
handler:(dispatch_block_t)handler;
|
|
|
|
/**
|
|
* This creates an item with a simple push-button interface, used to trigger an
|
|
* action. getTitleForPresentation is called each time the item is about to be
|
|
* presented, and should return the item's title.
|
|
*/
|
|
+ (instancetype)buttonItemWithTitleBlock:(RCTDevMenuItemTitleBlock)titleBlock
|
|
handler:(dispatch_block_t)handler;
|
|
|
|
@end
|
|
|
|
/**
|
|
* This category makes the developer menu instance available via the
|
|
* RCTBridge, which is useful for any class that needs to access the menu.
|
|
*/
|
|
@interface RCTBridge (RCTDevMenu)
|
|
|
|
@property (nonatomic, readonly) RCTDevMenu *devMenu;
|
|
|
|
@end
|