mirror of
https://github.com/status-im/react-native.git
synced 2025-01-25 08:48:58 +00:00
ddc374fac8
Summary: Hey, I've created a PR a few weeks ago #7264. It got merged in and then I received some emails and got mentioned in a few issues that it doesn't use renderAsOriginal prop on selectedIcon. Instead the app would use tint color. The problem can be seen here #7467. I've now added a method in TabBarItem that sets selectedIcon to renderAsOriginal if the prop is set. I added a "relay" icon to UIExplorer TabBarIOS example so you can see the item is now rendered in color as the image supplied. Oh and also should this PR be made from master. Had to work on this issue from 0.27 because the master was broken for me. Closes https://github.com/facebook/react-native/pull/7709 Differential Revision: D3339795 fbshipit-source-id: d8d4699bb617ecae8996a6627f3774c6473c19e0
112 lines
2.9 KiB
Objective-C
112 lines
2.9 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 "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
|
|
|
|
@synthesize barItem = _barItem;
|
|
|
|
- (instancetype)initWithFrame:(CGRect)frame
|
|
{
|
|
if ((self = [super initWithFrame:frame])) {
|
|
_systemIcon = NSNotFound;
|
|
}
|
|
return self;
|
|
}
|
|
|
|
- (UITabBarItem *)barItem
|
|
{
|
|
if (!_barItem) {
|
|
_barItem = [UITabBarItem new];
|
|
_systemIcon = NSNotFound;
|
|
}
|
|
return _barItem;
|
|
}
|
|
|
|
- (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;
|
|
}
|
|
}
|
|
|
|
- (UIViewController *)reactViewController
|
|
{
|
|
return self.superview.reactViewController;
|
|
}
|
|
|
|
@end
|