Giter Site home page Giter Site logo

kflyover's Introduction

react-native-flyover

A simple React Native native flyover for invoking Activity.startActivityForResult, Activity.setResult, and Activity.finish to help with implementing app-to-app communication.

Getting started

$ npm install react-native-flyover --save

Mostly automatic installation

$ react-native link react-native-flyover

Manual installation

Android

  1. Open up android/app/src/main/java/[...]/MainActivity.java
  • Add import com.kashish.FlyOverPackage; to the imports at the top of the file
  • Add new FlyOverPackage() to the list returned by the getPackages() method
  1. Append the following lines to android/settings.gradle:
    include ':react-native-flyover'
    project(':react-native-flyover').projectDir = new File(rootProject.projectDir, 	'../node_modules/react-native-flyover/android')
    
  2. Insert the following lines inside the dependencies block in android/app/build.gradle:
      compile project(':react-native-flyover')
    

Usage

import FlyOver from 'react-native-flyover';

// Check if an app is installed to handle an intent
const flyover = await FlyOver.resolveFlyOver('com.kashish.TARGET_INTENT');
if (!flyover) {
	console.warn('Please install the othe app.');
} else {
	console.log(`Activity will be handled by ${activity.package}`);
}

// naked startActivity replacement

FlyOver.startFlyOver('com.kashish.TARGET_INTENT', args);

// Start an activity for a result
let uniqueId = 0;
let args = /* ... */;
const response = await FlyOver.startFlyOverForResult(++uniqueId, 'com.kashish.TARGET_INTENT', args);
if (response.resultCode !== FlyOver.OK) {
  throw new Error('Invalid result from activity.');
} else {
  console.log('Got the following response: ' + response.data);
}

// Finish an activity with a result
KFlyOver.destroyFlyOver(FlyOver.OK, 'com.kashish.TARGET_INTENT', args);

kflyover's People

Contributors

souviktuky24 avatar

Watchers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.