/react-native-web-extended

Extended version of react-native-web

Primary LanguageJavaScriptOtherNOASSERTION

React Native Web Extended

npm version

"React Native Web Extended" is a fork of React Native Web, with more components migrated from React Native.

Patch for React Native Web is available in the patch/react-native-web branch.

Get Started

Install using npm:

npm install react-native-web-extended --save

Boilerplate is coming soon.

Extended components

Currently 3 more components from React Native are added.

Navigator

Navigator from React Native is re-implemented with react-router.

Usage:

render() {
  const routes = [
    {index: 0, title: 'Page 1'},
    {index: 1, title: 'Page 2'},
  ];
  return (
    <Navigator
      initialRoute={routes[0]}
      renderScene={(route, navigator) =>
        <TouchableHighlight onPress={() => {
          if (route.index === 0) {
            navigator.push(routes[1]);
          } else {
            navigator.pop();
          }
        }}>
        <Text>Hello! Route index is {route.index}, title is {route.title}</Text>
        </TouchableHighlight>
      }
      style={{padding: 100}}
    />
  );
}

Note:

  • Currently supported props: initialRoute, renderScene.
  • index key in the route object is required.
  • initialRouteStack prop is not supported, as we can't push multiple history states when the webpage loads.

TabBarIOS

Usage:

'use strict';

var React = require('react');
var ReactNative = require('react-native');
var {
  StyleSheet,
  TabBarIOS,
  Text,
  View,
} = ReactNative;

var base64Icon = '';

class TabBarExample extends React.Component {
  static title = '<TabBarIOS>';
  static description = 'Tab-based navigation.';
  static displayName = 'TabBarExample';

  state = {
    selectedTab: 'redTab',
    notifCount: 0,
    presses: 0,
  };

  _renderContent = (color: string, pageText: string, num?: number) => {
    return (
      <View style={[styles.tabContent, {backgroundColor: color}]}>
        <Text style={styles.tabText}>{pageText}</Text>
        <Text style={styles.tabText}>{num} re-renders of the {pageText}</Text>
      </View>
    );
  };

  render() {
    return (
      <TabBarIOS
        unselectedTintColor="yellow"
        tintColor="white"
        barTintColor="darkslateblue">
        <TabBarIOS.Item
          title="Blue Tab"
          icon={{uri: base64Icon, scale: 3}}
          selected={this.state.selectedTab === 'blueTab'}
          onPress={() => {
            this.setState({
              selectedTab: 'blueTab',
            });
          }}>
          {this._renderContent('#414A8C', 'Blue Tab')}
        </TabBarIOS.Item>
        <TabBarIOS.Item
          title="Tab 2"
          icon={{uri: base64Icon, scale: 3}}
          badge={this.state.notifCount > 0 ? this.state.notifCount : undefined}
          selected={this.state.selectedTab === 'redTab'}
          onPress={() => {
            this.setState({
              selectedTab: 'redTab',
              notifCount: this.state.notifCount + 1,
            });
          }}>
          {this._renderContent('#783E33', 'Red Tab', this.state.notifCount)}
        </TabBarIOS.Item>
        <TabBarIOS.Item
          icon={require('./flux.png')}
          selectedIcon={require('./relay.png')}
          title="More"
          selected={this.state.selectedTab === 'greenTab'}
          onPress={() => {
            this.setState({
              selectedTab: 'greenTab',
              presses: this.state.presses + 1
            });
          }}>
          {this._renderContent('#21551C', 'Green Tab', this.state.presses)}
        </TabBarIOS.Item>
      </TabBarIOS>
    );
  }
}

var styles = StyleSheet.create({
  tabContent: {
    flex: 1,
    alignItems: 'center',
  },
  tabText: {
    color: 'white',
    margin: 50,
  },
});

module.exports = TabBarExample;

note:

  • Supported props for TabBarIOS : barTintColor, tintColor, unselectedTintColor
  • Supported props for TabBarIOS.Item : title, icon, selectedIcon, onPress, selected, badge

RefreshControl

Usage:

class RefreshableList extends Component {
  constructor(props) {
    super(props);
    this.state = {
      refreshing: false,
    };
  }

  _onRefresh() {
    this.setState({refreshing: true});
    fetchData().then(() => {
      this.setState({refreshing: false});
    });
  }

  render() {
    return (
      <ListView
        refreshControl={
          <RefreshControl
            refreshing={this.state.refreshing}
            onRefresh={this._onRefresh.bind(this)}
          />
        }
        ...
      >
      ...
      </ListView>
    );
  }
  ...
}

Extended APIs

Alert

Alert box with IOS theme. Vendor: Alert7. Alias: AlertIOS

Usage:

//Basic Alert
Alert.alert('Title', 'Hello!');

//Multiple Buttons
Alert.alert(
  'Alert Title',
  'My Alert Msg',
  [
    {text: 'Ask me later', onPress: () => console.log('Ask me later pressed')},
    {text: 'Cancel', onPress: () => console.log('Cancel Pressed'), style: 'cancel'},
    {text: 'OK', onPress: () => console.log('OK Pressed')},
  ]
);

//Text Input
AlertIOS.prompt(
  'Title',
  'Enter a message',
  text => console.log("You entered "+text)
);