Browse Source

Revert "setStyle to style the according TabBar (#2524)"

This reverts commit abdb6e90a0.
yogevbd 7 years ago
parent
commit
0825bafcf3

+ 4
- 7
android/app/src/main/java/com/reactnativenavigation/layouts/BottomTabsLayout.java View File

16
 import com.facebook.react.bridge.Promise;
16
 import com.facebook.react.bridge.Promise;
17
 import com.facebook.react.bridge.WritableMap;
17
 import com.facebook.react.bridge.WritableMap;
18
 import com.reactnativenavigation.NavigationApplication;
18
 import com.reactnativenavigation.NavigationApplication;
19
-import com.reactnativenavigation.events.Event;
20
 import com.reactnativenavigation.events.EventBus;
19
 import com.reactnativenavigation.events.EventBus;
21
 import com.reactnativenavigation.events.ScreenChangedEvent;
20
 import com.reactnativenavigation.events.ScreenChangedEvent;
22
 import com.reactnativenavigation.params.ActivityParams;
21
 import com.reactnativenavigation.params.ActivityParams;
230
         for (int i = 0; i < bottomTabs.getItemsCount(); i++) {
229
         for (int i = 0; i < bottomTabs.getItemsCount(); i++) {
231
             screenStacks[i].updateScreenStyle(screenInstanceId, styleParams);
230
             screenStacks[i].updateScreenStyle(screenInstanceId, styleParams);
232
         }
231
         }
233
-
234
-        bottomTabs.setStyleFromScreen(this.getCurrentScreen().getStyleParams());
235
     }
232
     }
236
 
233
 
237
     @Override
234
     @Override
363
 
360
 
364
     private boolean hasBackgroundColor(StyleParams params) {
361
     private boolean hasBackgroundColor(StyleParams params) {
365
         return params.screenBackgroundColor != null &&
362
         return params.screenBackgroundColor != null &&
366
-                params.screenBackgroundColor.hasColor();
363
+            params.screenBackgroundColor.hasColor();
367
     }
364
     }
368
 
365
 
369
     private void setStyleFromScreen(StyleParams params) {
366
     private void setStyleFromScreen(StyleParams params) {
394
         performOnStack(params.getNavigatorId(), new Task<ScreenStack>() {
391
         performOnStack(params.getNavigatorId(), new Task<ScreenStack>() {
395
             @Override
392
             @Override
396
             public void run(ScreenStack stack) {
393
             public void run(ScreenStack stack) {
397
-                stack.pop(params.animateScreenTransitions, params.timestamp, new ScreenStack.OnScreenPop() {
394
+            stack.pop(params.animateScreenTransitions, params.timestamp, new ScreenStack.OnScreenPop() {
398
                     @Override
395
                     @Override
399
                     public void onScreenPopAnimationEnd() {
396
                     public void onScreenPopAnimationEnd() {
400
                         setBottomTabsStyleFromCurrentScreen();
397
                         setBottomTabsStyleFromCurrentScreen();
453
             task.run(screenStack);
450
             task.run(screenStack);
454
         } catch (ScreenStackNotFoundException e) {
451
         } catch (ScreenStackNotFoundException e) {
455
             Log.e("Navigation", "Could not perform action on stack [" + navigatorId + "]." +
452
             Log.e("Navigation", "Could not perform action on stack [" + navigatorId + "]." +
456
-                    "This should not have happened, it probably means a navigator action" +
457
-                    "was called from an unmounted tab.");
453
+                                      "This should not have happened, it probably means a navigator action" +
454
+                                      "was called from an unmounted tab.");
458
         }
455
         }
459
     }
456
     }
460
 
457
 

+ 0
- 8
android/app/src/main/java/com/reactnativenavigation/params/parsers/StyleParamsParser.java View File

131
         result.titleBarHeight = -1;
131
         result.titleBarHeight = -1;
132
         result.screenAnimationType = "slide-up";
132
         result.screenAnimationType = "slide-up";
133
         result.drawUnderStatusBar = false;
133
         result.drawUnderStatusBar = false;
134
-
135
-        result.bottomTabsColor = getDefaultBottomTabsColor();
136
-        result.bottomTabsButtonColor = getDefaultBottomTabsButtonColor();
137
-        result.selectedBottomTabsButtonColor = getDefaultSelectedBottomTabsButtonColor();
138
-
139
-        result.bottomTabBadgeTextColor = getBottomTabBadgeTextColor();
140
-        result.bottomTabBadgeBackgroundColor = getBottomTabBadgeBackgroundColor();
141
-
142
         return result;
134
         return result;
143
     }
135
     }
144
 
136
 

+ 1
- 1
android/app/src/main/java/com/reactnativenavigation/screens/Screen.java View File

216
     }
216
     }
217
 
217
 
218
     public void setTitleBarTitle(String title) {
218
     public void setTitleBarTitle(String title) {
219
-        topBar.setTitle(title, styleParams);
219
+       topBar.setTitle(title, styleParams);
220
     }
220
     }
221
 
221
 
222
     public void setTitleBarSubtitle(String subtitle) {
222
     public void setTitleBarSubtitle(String subtitle) {

+ 28
- 22
android/app/src/main/java/com/reactnativenavigation/views/BottomTabs.java View File

2
 
2
 
3
 import android.content.Context;
3
 import android.content.Context;
4
 import android.graphics.Color;
4
 import android.graphics.Color;
5
-import android.os.Bundle;
6
 import android.text.TextUtils;
5
 import android.text.TextUtils;
7
 
6
 
8
 import com.aurelhubert.ahbottomnavigation.AHBottomNavigation;
7
 import com.aurelhubert.ahbottomnavigation.AHBottomNavigation;
11
 import com.reactnativenavigation.params.AppStyle;
10
 import com.reactnativenavigation.params.AppStyle;
12
 import com.reactnativenavigation.params.ScreenParams;
11
 import com.reactnativenavigation.params.ScreenParams;
13
 import com.reactnativenavigation.params.StyleParams;
12
 import com.reactnativenavigation.params.StyleParams;
14
-import com.reactnativenavigation.params.parsers.StyleParamsParser;
15
 import com.reactnativenavigation.utils.ViewUtils;
13
 import com.reactnativenavigation.utils.ViewUtils;
16
 import com.reactnativenavigation.views.utils.Constants;
14
 import com.reactnativenavigation.views.utils.Constants;
17
 
15
 
23
 
21
 
24
     public BottomTabs(Context context) {
22
     public BottomTabs(Context context) {
25
         super(context);
23
         super(context);
26
-
27
         setForceTint(true);
24
         setForceTint(true);
28
         setId(ViewUtils.generateViewId());
25
         setId(ViewUtils.generateViewId());
29
         createVisibilityAnimator();
26
         createVisibilityAnimator();
30
-        setStyle(AppStyle.appStyle);
27
+        setStyle();
31
         setFontFamily();
28
         setFontFamily();
32
     }
29
     }
33
 
30
 
34
     public void addTabs(List<ScreenParams> params, OnTabSelectedListener onTabSelectedListener) {
31
     public void addTabs(List<ScreenParams> params, OnTabSelectedListener onTabSelectedListener) {
35
         for (ScreenParams screenParams : params) {
32
         for (ScreenParams screenParams : params) {
36
-            AHBottomNavigationItem item = new AHBottomNavigationItem(screenParams.tabLabel, screenParams.tabIcon, Color.GRAY);
33
+            AHBottomNavigationItem item = new AHBottomNavigationItem(screenParams.tabLabel, screenParams.tabIcon,
34
+                    Color.GRAY);
37
             addItem(item);
35
             addItem(item);
38
             setOnTabSelectedListener(onTabSelectedListener);
36
             setOnTabSelectedListener(onTabSelectedListener);
39
         }
37
         }
41
     }
39
     }
42
 
40
 
43
     public void setStyleFromScreen(StyleParams params) {
41
     public void setStyleFromScreen(StyleParams params) {
44
-        this.setStyle(params);
42
+        if (params.bottomTabsColor.hasColor()) {
43
+            setBackgroundColor(params.bottomTabsColor);
44
+        }
45
+        if (params.bottomTabsButtonColor.hasColor()) {
46
+            if (getInactiveColor() != params.bottomTabsButtonColor.getColor()) {
47
+                setInactiveColor(params.bottomTabsButtonColor.getColor());
48
+            }
49
+        }
50
+        if (params.selectedBottomTabsButtonColor.hasColor()) {
51
+            if (getAccentColor() != params.selectedBottomTabsButtonColor.getColor()) {
52
+                setAccentColor(params.selectedBottomTabsButtonColor.getColor());
53
+            }
54
+        }
45
 
55
 
46
         setVisibility(params.bottomTabsHidden, true);
56
         setVisibility(params.bottomTabsHidden, true);
47
     }
57
     }
122
                 Constants.BOTTOM_TABS_HEIGHT);
132
                 Constants.BOTTOM_TABS_HEIGHT);
123
     }
133
     }
124
 
134
 
125
-    private void setStyle(StyleParams params) {
126
-        if (params.bottomTabBadgeBackgroundColor.hasColor()) {
135
+    private void setStyle() {
136
+        if (hasBadgeBackgroundColor()) {
127
             setNotificationBackgroundColor(AppStyle.appStyle.bottomTabBadgeBackgroundColor.getColor());
137
             setNotificationBackgroundColor(AppStyle.appStyle.bottomTabBadgeBackgroundColor.getColor());
128
         }
138
         }
129
-        if (params.bottomTabBadgeTextColor.hasColor()) {
139
+        if (hasBadgeTextColor()) {
130
             setNotificationTextColor(AppStyle.appStyle.bottomTabBadgeTextColor.getColor());
140
             setNotificationTextColor(AppStyle.appStyle.bottomTabBadgeTextColor.getColor());
131
         }
141
         }
142
+    }
132
 
143
 
133
-        if (params.bottomTabsColor.hasColor()) {
134
-            setBackgroundColor(params.bottomTabsColor);
135
-        }
136
-        if (params.bottomTabsButtonColor.hasColor()) {
137
-            if (getInactiveColor() != params.bottomTabsButtonColor.getColor()) {
138
-                setInactiveColor(params.bottomTabsButtonColor.getColor());
139
-            }
140
-        }
141
-        if (params.selectedBottomTabsButtonColor.hasColor()) {
142
-            if (getAccentColor() != params.selectedBottomTabsButtonColor.getColor()) {
143
-                setAccentColor(params.selectedBottomTabsButtonColor.getColor());
144
-            }
145
-        }
144
+    private boolean hasBadgeTextColor() {
145
+        return AppStyle.appStyle.bottomTabBadgeTextColor != null &&
146
+               AppStyle.appStyle.bottomTabBadgeTextColor.hasColor();
147
+    }
148
+
149
+    private boolean hasBadgeBackgroundColor() {
150
+        return AppStyle.appStyle.bottomTabBadgeBackgroundColor != null &&
151
+               AppStyle.appStyle.bottomTabBadgeBackgroundColor.hasColor();
146
     }
152
     }
147
 
153
 
148
     private void setFontFamily() {
154
     private void setFontFamily() {

+ 17
- 17
ios/RCCNavigationController.m View File

339
   // setStyle
339
   // setStyle
340
   if ([performAction isEqualToString:@"setStyle"])
340
   if ([performAction isEqualToString:@"setStyle"])
341
   {
341
   {
342
-    for (UIViewController *viewController in self.viewControllers) {
343
-      if ([viewController isKindOfClass:[RCCViewController class]])
344
-      {
345
-        RCCViewController *rccViewController = (RCCViewController*)viewController;
346
-        
347
-        NSDictionary *navigatorStyle = [[NSDictionary alloc] initWithDictionary:actionParams copyItems:YES];
348
-        NSMutableDictionary *mergedStyle = [NSMutableDictionary dictionaryWithDictionary:rccViewController.navigatorStyle];
349
-        
350
-        // there are a few styles that we don't want to remember from our parent (they should be local)
351
-        [mergedStyle setValuesForKeysWithDictionary:navigatorStyle];
352
-        navigatorStyle = mergedStyle;
353
-        
354
-        rccViewController.navigatorStyle = navigatorStyle;
355
-        
356
-        [rccViewController setStyleOnInit];
357
-        [rccViewController updateStyle];
358
-      }
342
+    
343
+    NSDictionary *navigatorStyle = actionParams;
344
+    
345
+    // merge the navigatorStyle of our parent
346
+    if ([self.topViewController isKindOfClass:[RCCViewController class]])
347
+    {
348
+      RCCViewController *parent = (RCCViewController*)self.topViewController;
349
+      NSMutableDictionary *mergedStyle = [NSMutableDictionary dictionaryWithDictionary:parent.navigatorStyle];
350
+      
351
+      // there are a few styles that we don't want to remember from our parent (they should be local)
352
+      [mergedStyle setValuesForKeysWithDictionary:navigatorStyle];
353
+      navigatorStyle = mergedStyle;
354
+      
355
+      parent.navigatorStyle = navigatorStyle;
356
+      
357
+      [parent setStyleOnInit];
358
+      [parent updateStyle];
359
     }
359
     }
360
   }
360
   }
361
 }
361
 }

+ 0
- 1
ios/RCCTabBarController.h View File

5
 
5
 
6
 - (instancetype)initWithProps:(NSDictionary *)props children:(NSArray *)children globalProps:(NSDictionary*)globalProps bridge:(RCTBridge *)bridge;
6
 - (instancetype)initWithProps:(NSDictionary *)props children:(NSArray *)children globalProps:(NSDictionary*)globalProps bridge:(RCTBridge *)bridge;
7
 - (void)performAction:(NSString*)performAction actionParams:(NSDictionary*)actionParams bridge:(RCTBridge *)bridge completion:(void (^)(void))completion;
7
 - (void)performAction:(NSString*)performAction actionParams:(NSDictionary*)actionParams bridge:(RCTBridge *)bridge completion:(void (^)(void))completion;
8
-+ (UIImage *)image:(UIImage*)image withColor:(UIColor *)color1;
9
 
8
 
10
 @property (nonatomic) BOOL tabBarHidden;
9
 @property (nonatomic) BOOL tabBarHidden;
11
 
10
 

+ 3
- 3
ios/RCCTabBarController.m View File

55
   return YES;
55
   return YES;
56
 }
56
 }
57
 
57
 
58
-+ (UIImage *)image:(UIImage*)image withColor:(UIColor *)color1
58
+- (UIImage *)image:(UIImage*)image withColor:(UIColor *)color1
59
 {
59
 {
60
   UIGraphicsBeginImageContextWithOptions(image.size, NO, image.scale);
60
   UIGraphicsBeginImageContextWithOptions(image.size, NO, image.scale);
61
   CGContextRef context = UIGraphicsGetCurrentContext();
61
   CGContextRef context = UIGraphicsGetCurrentContext();
159
       iconImage = [RCTConvert UIImage:icon];
159
       iconImage = [RCTConvert UIImage:icon];
160
       if (buttonColor)
160
       if (buttonColor)
161
       {
161
       {
162
-        iconImage = [[RCCTabBarController image:iconImage withColor:buttonColor] imageWithRenderingMode:UIImageRenderingModeAlwaysOriginal];
162
+        iconImage = [[self image:iconImage withColor:buttonColor] imageWithRenderingMode:UIImageRenderingModeAlwaysOriginal];
163
       }
163
       }
164
     }
164
     }
165
     UIImage *iconImageSelected = nil;
165
     UIImage *iconImageSelected = nil;
327
       if (icon && icon != (id)[NSNull null])
327
       if (icon && icon != (id)[NSNull null])
328
       {
328
       {
329
         iconImage = [RCTConvert UIImage:icon];
329
         iconImage = [RCTConvert UIImage:icon];
330
-        iconImage = [[RCCTabBarController image:iconImage withColor:self.tabBar.tintColor] imageWithRenderingMode:UIImageRenderingModeAlwaysOriginal];
330
+        iconImage = [[self image:iconImage withColor:self.tabBar.tintColor] imageWithRenderingMode:UIImageRenderingModeAlwaysOriginal];
331
         viewController.tabBarItem.image = iconImage;
331
         viewController.tabBarItem.image = iconImage;
332
       }
332
       }
333
       
333
       

+ 4
- 88
ios/RCCViewController.m View File

494
     [viewController setNeedsStatusBarAppearanceUpdate];
494
     [viewController setNeedsStatusBarAppearanceUpdate];
495
   }
495
   }
496
   
496
   
497
-  if (viewController.tabBarController && viewController.tabBarController.tabBar != (id)[NSNull null]) {
497
+  NSNumber *tabBarHidden = self.navigatorStyle[@"tabBarHidden"];
498
+  BOOL tabBarHiddenBool = tabBarHidden ? [tabBarHidden boolValue] : NO;
499
+  if (tabBarHiddenBool) {
498
     UITabBar *tabBar = viewController.tabBarController.tabBar;
500
     UITabBar *tabBar = viewController.tabBarController.tabBar;
499
-    
500
-    if (tabBar && tabBar != (id)[NSNull null]) {
501
-      UIColor *buttonColor = nil;
502
-      UIColor *selectedButtonColor = nil;
503
-      UIColor *labelColor = nil;
504
-      UIColor *selectedLabelColor = nil;
505
-      
506
-      NSNumber *tabBarHidden = self.navigatorStyle[@"tabBarHidden"];
507
-      BOOL tabBarHiddenBool = tabBarHidden ? [tabBarHidden boolValue] : NO;
508
-      if (tabBarHiddenBool) {
509
-        tabBar.transform = CGAffineTransformMakeTranslation(0, tabBar.frame.size.height);
510
-      }
511
-      
512
-      NSString *tabBarButtonColor = self.navigatorStyle[@"tabBarButtonColor"];
513
-      NSString *tabBarSelectedButtonColor = self.navigatorStyle[@"tabBarSelectedButtonColor"];
514
-      
515
-      if (tabBarButtonColor)
516
-      {
517
-        buttonColor = tabBarButtonColor != (id)[NSNull null] ? [RCTConvert UIColor:tabBarButtonColor] : nil;
518
-        
519
-        if (tabBarSelectedButtonColor) {
520
-          selectedButtonColor = tabBarSelectedButtonColor != (id)[NSNull null] ? [RCTConvert UIColor:tabBarSelectedButtonColor] : nil;
521
-          
522
-          tabBar.tintColor = selectedLabelColor = selectedButtonColor;
523
-          tabBar.unselectedItemTintColor = labelColor = buttonColor;
524
-        }
525
-        else {
526
-          tabBar.tintColor = labelColor = buttonColor;
527
-        }
528
-      }
529
-      else if (tabBarSelectedButtonColor) {
530
-        selectedButtonColor = tabBarSelectedButtonColor != (id)[NSNull null] ? [RCTConvert UIColor:tabBarSelectedButtonColor] : nil;
531
-        tabBar.tintColor = selectedLabelColor = selectedButtonColor;
532
-      }
533
-      
534
-      NSString *tabBarLabelColor = self.navigatorStyle[@"tabBarLabelColor"];
535
-      if(tabBarLabelColor) {
536
-        UIColor *color = tabBarLabelColor != (id)[NSNull null] ? [RCTConvert UIColor:tabBarLabelColor] : nil;
537
-        labelColor = color;
538
-      }
539
-      NSString *tabBarSelectedLabelColor = self.navigatorStyle[@"tabBarSelectedLabelColor"];
540
-      if(tabBarLabelColor) {
541
-        UIColor *color = tabBarSelectedLabelColor != (id)[NSNull null] ? [RCTConvert UIColor:tabBarSelectedLabelColor] : nil;
542
-        selectedLabelColor = color;
543
-      }
544
-      
545
-      NSString *tabBarBackgroundColor = self.navigatorStyle[@"tabBarBackgroundColor"];
546
-      if (tabBarBackgroundColor)
547
-      {
548
-        UIColor *color = tabBarBackgroundColor != (id)[NSNull null] ? [RCTConvert UIColor:tabBarBackgroundColor] : nil;
549
-        tabBar.barTintColor = color;
550
-      }
551
-      
552
-      NSNumber *tabBarTranslucent = self.navigatorStyle[@"tabBarTranslucent"];
553
-      if (tabBarTranslucent)
554
-      {
555
-        BOOL tabBarTranslucentBool = tabBarTranslucent ? [tabBarTranslucent boolValue] : NO;
556
-        tabBar.translucent = tabBarTranslucentBool;
557
-      }
558
-      
559
-      NSNumber *tabBarHideShadow = self.navigatorStyle[@"tabBarHideShadow"];
560
-      if (tabBarHideShadow)
561
-      {
562
-        BOOL tabBarHideShadowBool = tabBarHideShadow ? [tabBarHideShadow boolValue] : NO;
563
-        tabBar.clipsToBounds = tabBarHideShadowBool ? YES : NO;
564
-      }
565
-      
566
-      for (UIViewController *tabViewController in [viewController.tabBarController viewControllers]) {
567
-        NSMutableDictionary *unselectedAttributes = [RCTHelpers textAttributesFromDictionary:self.navigatorStyle withPrefix:@"tabBarText" baseFont:[UIFont systemFontOfSize:10]];
568
-        if (!unselectedAttributes[NSForegroundColorAttributeName] && labelColor) {
569
-          unselectedAttributes[NSForegroundColorAttributeName] = labelColor;
570
-        }
571
-        [tabViewController.tabBarItem setTitleTextAttributes:unselectedAttributes forState:UIControlStateNormal];
572
-        
573
-        
574
-        NSMutableDictionary *selectedAttributes = [RCTHelpers textAttributesFromDictionary:self.navigatorStyle withPrefix:@"tabBarSelectedText" baseFont:[UIFont systemFontOfSize:10]];
575
-        if (!selectedAttributes[NSForegroundColorAttributeName] && selectedLabelColor) {
576
-          selectedAttributes[NSForegroundColorAttributeName] = selectedLabelColor;
577
-        }
578
-        [tabViewController.tabBarItem setTitleTextAttributes:selectedAttributes forState:UIControlStateSelected];
579
-        
580
-        if (buttonColor)
581
-        {
582
-          tabViewController.tabBarItem.image = [[RCCTabBarController image:tabViewController.tabBarItem.image withColor:buttonColor] imageWithRenderingMode:UIImageRenderingModeAlwaysOriginal];
583
-        }
584
-      }
585
-    }
501
+    tabBar.transform = CGAffineTransformMakeTranslation(0, tabBar.frame.size.height);
586
   }
502
   }
587
 
503
 
588
   NSNumber *navBarHidden = self.navigatorStyle[@"navBarHidden"];
504
   NSNumber *navBarHidden = self.navigatorStyle[@"navBarHidden"];