mirror of
https://github.com/status-im/react-native.git
synced 2025-01-21 23:09:22 +00:00
1490ab12ef
Summary: Includes React Native and its dependencies Fresco, Metro, and Yoga. Excludes samples/examples/docs. find: ^(?:( *)|( *(?:[\*~#]|::))( )? *)?Copyright (?:\(c\) )?(\d{4})\b.+Facebook[\s\S]+?BSD[\s\S]+?(?:this source tree|the same directory)\.$ replace: $1$2$3Copyright (c) $4-present, Facebook, Inc.\n$2\n$1$2$3This source code is licensed under the MIT license found in the\n$1$2$3LICENSE file in the root directory of this source tree. Reviewed By: TheSavior, yungsters Differential Revision: D7007050 fbshipit-source-id: 37dd6bf0ffec0923bfc99c260bb330683f35553e
140 lines
3.3 KiB
Objective-C
140 lines
3.3 KiB
Objective-C
/**
|
|
* Copyright (c) 2015-present, Facebook, Inc.
|
|
*
|
|
* This source code is licensed under the MIT license found in the
|
|
* LICENSE file in the root directory of this source tree.
|
|
*/
|
|
|
|
#import "RCTTabBarItem.h"
|
|
|
|
#import "RCTConvert.h"
|
|
#import "RCTLog.h"
|
|
#import "UIView+React.h"
|
|
|
|
@implementation RCTConvert (UITabBarSystemItem)
|
|
|
|
RCT_ENUM_CONVERTER(UITabBarSystemItem, (@{
|
|
@"bookmarks": @(UITabBarSystemItemBookmarks),
|
|
@"contacts": @(UITabBarSystemItemContacts),
|
|
@"downloads": @(UITabBarSystemItemDownloads),
|
|
@"favorites": @(UITabBarSystemItemFavorites),
|
|
@"featured": @(UITabBarSystemItemFeatured),
|
|
@"history": @(UITabBarSystemItemHistory),
|
|
@"more": @(UITabBarSystemItemMore),
|
|
@"most-recent": @(UITabBarSystemItemMostRecent),
|
|
@"most-viewed": @(UITabBarSystemItemMostViewed),
|
|
@"recents": @(UITabBarSystemItemRecents),
|
|
@"search": @(UITabBarSystemItemSearch),
|
|
@"top-rated": @(UITabBarSystemItemTopRated),
|
|
}), NSNotFound, integerValue)
|
|
|
|
@end
|
|
|
|
@implementation RCTTabBarItem{
|
|
UITapGestureRecognizer *_selectRecognizer;
|
|
}
|
|
|
|
@synthesize barItem = _barItem;
|
|
|
|
- (instancetype)initWithFrame:(CGRect)frame
|
|
{
|
|
if ((self = [super initWithFrame:frame])) {
|
|
_systemIcon = NSNotFound;
|
|
#if TARGET_OS_TV
|
|
_wasSelectedInJS = NO;
|
|
#endif
|
|
}
|
|
return self;
|
|
}
|
|
|
|
- (UITabBarItem *)barItem
|
|
{
|
|
if (!_barItem) {
|
|
_barItem = [UITabBarItem new];
|
|
_systemIcon = NSNotFound;
|
|
}
|
|
return _barItem;
|
|
}
|
|
|
|
- (void)setTestID:(NSString *)testID
|
|
{
|
|
self.barItem.accessibilityIdentifier = testID;
|
|
}
|
|
|
|
- (void)setBadge:(id)badge
|
|
{
|
|
_badge = [badge copy];
|
|
self.barItem.badgeValue = [badge description];
|
|
}
|
|
|
|
- (void)setSystemIcon:(UITabBarSystemItem)systemIcon
|
|
{
|
|
if (_systemIcon != systemIcon) {
|
|
_systemIcon = systemIcon;
|
|
UITabBarItem *oldItem = _barItem;
|
|
_barItem = [[UITabBarItem alloc] initWithTabBarSystemItem:_systemIcon
|
|
tag:oldItem.tag];
|
|
_barItem.title = oldItem.title;
|
|
_barItem.imageInsets = oldItem.imageInsets;
|
|
_barItem.badgeValue = oldItem.badgeValue;
|
|
}
|
|
}
|
|
|
|
- (void)setIcon:(UIImage *)icon
|
|
{
|
|
_icon = icon;
|
|
if (_icon && _systemIcon != NSNotFound) {
|
|
_systemIcon = NSNotFound;
|
|
UITabBarItem *oldItem = _barItem;
|
|
_barItem = [UITabBarItem new];
|
|
_barItem.title = oldItem.title;
|
|
_barItem.imageInsets = oldItem.imageInsets;
|
|
_barItem.selectedImage = oldItem.selectedImage;
|
|
_barItem.badgeValue = oldItem.badgeValue;
|
|
}
|
|
|
|
if (_renderAsOriginal) {
|
|
self.barItem.image = [_icon imageWithRenderingMode:UIImageRenderingModeAlwaysOriginal];
|
|
} else {
|
|
self.barItem.image = _icon;
|
|
}
|
|
}
|
|
|
|
- (void)setSelectedIcon:(UIImage *)selectedIcon
|
|
{
|
|
_selectedIcon = selectedIcon;
|
|
|
|
if (_renderAsOriginal) {
|
|
self.barItem.selectedImage = [_selectedIcon imageWithRenderingMode:UIImageRenderingModeAlwaysOriginal];
|
|
} else {
|
|
self.barItem.selectedImage = _selectedIcon;
|
|
}
|
|
}
|
|
|
|
- (void)setBadgeColor:(UIColor *)badgeColor
|
|
{
|
|
// badgeColor available since iOS 10
|
|
if ([self.barItem respondsToSelector:@selector(badgeColor)]) {
|
|
self.barItem.badgeColor = badgeColor;
|
|
}
|
|
}
|
|
|
|
- (UIViewController *)reactViewController
|
|
{
|
|
return self.superview.reactViewController;
|
|
}
|
|
|
|
#if TARGET_OS_TV
|
|
|
|
// On Apple TV, we let native control the tab bar selection after initial render
|
|
- (void)setSelected:(BOOL)selected
|
|
{
|
|
if (!_wasSelectedInJS) {
|
|
_selected = selected;
|
|
}
|
|
}
|
|
|
|
#endif
|
|
|
|
@end
|