Skip to content

Latest commit

 

History

History
146 lines (106 loc) · 4.28 KB

README.md

File metadata and controls

146 lines (106 loc) · 4.28 KB

react-native-meteor

react-native-meteor npm version

Meteor-like methods for React Native.

What is it for ?

The purpose of this library is :

  • To set up and maintain a ddp connection with a ddp server, freeing the developer from having to do it on their own.
  • Be fully compatible with react-native and help react-native developers.
  • To match with Meteor documentation used with React.

Install

yarn add pmogollons/react-native-meteor

and you also need to install peer dependencies

yarn add @react-native-community/netinfo @react-native-community/async-storage

See detailed installation guide

Compatibility notes

Since RN 0.60+ the original package was not compatible, this repo makes some changes to fix that and:

  • Use netinfo and asyncstorage from its community packages
  • Now call, loginWithPassword, logout and logoutOtherClients return promises
  • Removed callbacks from call, loginWithPassword, logout, logoutOtherClients
  • Added onLogout event
  • Method.call promise has a configurable timeout and checks for connection before making the call. (This improved error handling in our apps)
  • Removed FSCollection modules
  • Removed MeteorListView, MeteorComplexListView, createContainer, composeWithTracker, ReactMixin
  • Updated deps and removed unused ones
  • Partially updated code to es6+
  • Dont clear connections on reconnect.

Future

  • We dont intend to support this package in the long run, it will be supported for the time we keep using it.
  • We might add the components and modules we use to handle grapher queries to this repo.

Example usage

import React, {Component} from 'react';
import Meteor, {withTracker} from 'react-native-meteor';
import {View, Text, Alert, FlatList, TouchableOpacity} from 'react-native';

Meteor.connect('ws://192.168.X.X:3000/websocket'); //do this only once

class App extends Component {
  state = {
    isLoading: false,
  };

  _callMethod = async () => {
    this.setState({isLoading: true});

    try {
      // Default timeout is 15,000 (15secs)
      await Meteor.call('methodName', params, {timeout: 5000});
    } catch (error) {
      Alert.alert('There was an error!', error.reason);
    } finally {
      this.setState({isLoading: false});
    }
  };

  _login = async () => {
    this.setState({isLoading: true});

    try {
      await Meteor.loginWithPassword(email, password);
    } catch (error) {
      Alert.alert('There was an error!', error.reason);
    } finally {
      this.setState({isLoading: false});
    }
  };

  _renderItem(todo) {
    return <Text>{todo.title}</Text>;
  }

  render() {
    const {settings, todosReady} = this.props;

    return (
      <View>
        <Text>{settings.title}</Text>

        <TouchableOpacity onPress={this._callMethod}>
          <Text>{this.state.isLoading ? 'Loading...' : 'Do something'}</Text>
        </TouchableOpacity>

        <TouchableOpacity onPress={this._login}>
          <Text>{this.state.isLoading ? 'Logging in...' : 'Login'}</Text>
        </TouchableOpacity>

        {!todosReady && <Text>Not ready</Text>}

        <FlatList
          data={this.props.data}
          renderItem={this._renderItem}
          keyExtractor={item => item._id}
        />
      </View>
    );
  }
}

export default withTracker(params => {
  const handle = Meteor.subscribe('todos');
  Meteor.subscribe('settings');

  return {
    todosReady: handle.ready(),
    settings: Meteor.collection('settings').findOne(),
  };
})(App);

Documentation

Want to help ?

Pull Requests and issues reported are welcome! :)

Authors

License

react-native-meteor is MIT Licensed.