Skip to content
This repository has been archived by the owner on Feb 25, 2020. It is now read-only.

Commit

Permalink
feat: add accessibilityLabel and testID options (#26)
Browse files Browse the repository at this point in the history
  • Loading branch information
dbasedow authored and satya164 committed Jun 3, 2018
1 parent c440543 commit 6337769
Show file tree
Hide file tree
Showing 6 changed files with 45 additions and 12 deletions.
1 change: 0 additions & 1 deletion example/src/MaterialTopTabs.js
Original file line number Diff line number Diff line change
@@ -1,5 +1,4 @@
import * as React from 'react';
import { View, Text } from 'react-native';
import { createMaterialTopTabNavigator } from 'react-navigation-tabs';
import PhotoGrid from './shared/PhotoGrid';

Expand Down
4 changes: 4 additions & 0 deletions src/navigators/createBottomTabNavigator.js
Original file line number Diff line number Diff line change
Expand Up @@ -56,6 +56,8 @@ class TabNavigationView extends React.PureComponent<Props, State> {
navigation,
screenProps,
getLabelText,
getAccessibilityLabel,
getTestID,
renderIcon,
onTabPress,
} = this.props;
Expand All @@ -78,6 +80,8 @@ class TabNavigationView extends React.PureComponent<Props, State> {
screenProps={screenProps}
onTabPress={onTabPress}
getLabelText={getLabelText}
getAccessibilityLabel={getAccessibilityLabel}
getTestID={getTestID}
renderIcon={renderIcon}
/>
);
Expand Down
14 changes: 3 additions & 11 deletions src/navigators/createMaterialTopTabNavigator.js
Original file line number Diff line number Diff line change
Expand Up @@ -45,16 +45,6 @@ class MaterialTabView extends React.PureComponent<Props> {
return route.routeName;
};

_getTestIDProps = ({ route, focused }) => {
const { descriptors } = this.props;
const descriptor = descriptors[route.key];
const options = descriptor.options;

return typeof options.tabBarTestIDProps === 'function'
? options.tabBarTestIDProps({ focused })
: options.tabBarTestIDProps;
};

_renderIcon = ({ focused, route, tintColor }) => {
const { descriptors } = this.props;
const descriptor = descriptors[route.key];
Expand Down Expand Up @@ -90,14 +80,16 @@ class MaterialTabView extends React.PureComponent<Props> {
}

return (
/* $FlowFixMe */
<TabBarComponent
{...tabBarOptions}
{...props}
tabBarPosition={tabBarPosition}
screenProps={this.props.screenProps}
navigation={this.props.navigation}
getLabelText={this.props.getLabelText}
getTestIDProps={this._getTestIDProps}
getAccessibilityLabel={this.props.getAccessibilityLabel}
getTestID={this.props.getTestID}
renderIcon={this._renderIcon}
onTabPress={this.props.onTabPress}
/>
Expand Down
28 changes: 28 additions & 0 deletions src/utils/createTabNavigator.js
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,8 @@ import {

export type InjectedProps = {
getLabelText: (props: { route: any }) => any,
getAccessibilityLabel: (props: { route: any }) => string,
getTestID: (props: { route: any }) => string,
renderIcon: (props: {
route: any,
focused: boolean,
Expand Down Expand Up @@ -70,6 +72,30 @@ export default function createTabNavigator(TabView: React.ComponentType<*>) {
return route.routeName;
};

_getAccessibilityLabel = ({ route }) => {
const { descriptors } = this.props;
const descriptor = descriptors[route.key];
const options = descriptor.options;

if (typeof options.tabBarAccessibility !== 'undefined') {
return options.tabBarAccessibilityLabel;
}

const label = this._getLabelText({ route });

if (typeof label === 'string') {
return label;
}
};

_getTestID = ({ route }) => {
const { descriptors } = this.props;
const descriptor = descriptors[route.key];
const options = descriptor.options;

return options.tabBarTestID;
};

_handleTabPress = ({ route }) => {
this._isTabPress = true;

Expand Down Expand Up @@ -125,6 +151,8 @@ export default function createTabNavigator(TabView: React.ComponentType<*>) {
<TabView
{...options}
getLabelText={this._getLabelText}
getAccessibilityLabel={this._getAccessibilityLabel}
getTestID={this._getTestID}
renderIcon={this._renderIcon}
renderScene={this._renderScene}
onIndexChange={this._handleIndexChange}
Expand Down
8 changes: 8 additions & 0 deletions src/views/BottomTabBar.js
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,8 @@ type Props = TabBarOptions & {
jumpTo: any,
onTabPress: any,
getLabelText: ({ route: any }) => any,
getAccessibilityLabel: (props: { route: any }) => string,
getTestID: (props: { route: any }) => string,
renderIcon: any,
dimensions: { width: number, height: number },
isLandscape: boolean,
Expand Down Expand Up @@ -192,6 +194,10 @@ class TabBarBottom extends React.Component<Props> {
{routes.map((route, index) => {
const focused = index === navigation.state.index;
const scene = { route, focused };
const accessibilityLabel = this.props.getAccessibilityLabel({
route,
});
const testID = this.props.getTestID({ route });

const backgroundColor = focused
? activeBackgroundColor
Expand All @@ -204,6 +210,8 @@ class TabBarBottom extends React.Component<Props> {
onTabPress({ route });
jumpTo(route.key);
}}
testID={testID}
accessibilityLabel={accessibilityLabel}
>
<View
style={[
Expand Down
2 changes: 2 additions & 0 deletions src/views/MaterialTopTabBar.js
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,8 @@ type Props = TabBarOptions & {
tintColor: string,
}) => React.Node,
getLabelText: (props: { route: any }) => any,
getAccessibilityLabel: (props: { route: any }) => string,
getTestID: (props: { route: any }) => string,
useNativeDriver?: boolean,
jumpTo: (key: string) => any,
};
Expand Down

0 comments on commit 6337769

Please sign in to comment.