Skip to content

Latest commit

 

History

History
55 lines (35 loc) · 3.04 KB

README.md

File metadata and controls

55 lines (35 loc) · 3.04 KB

WebApiBridge

WebApiBridge provides a function call API interface between Javascript processes that pass MessageEvent objects such as a a web page and an iframe or a React Native application and a web app running in a react-native-webview.

Features

  • Provides support for API calls between JavaScript processes. Each process can support API calls in an array of JavaScript objects (inluding React components)
  • Marshalls plain JavaScript parameters and return values via JSON.stringify() to work with react-native-community/react-native-webview, including support of ReactNativeWebView.postMessage
  • Works for communication between a web page and iframe child window
  • Provides promise support for asynchronous API calls that need to return results
  • Marshalls exceptions thown in API calls to the caller
  • Validates the existance of API call and message delivery so reliability errors are reported
  • Supports origin and targetOrigin settings
  • A listener() function hook is provided for debugging that will be passed all messages sent/received

Installation

If you're using npm:

npm install --save @precor/web-api-bridge

or, if you're using yarn:

yarn add @precor/web-api-bridge

Type Checking

a Typescript definition file is included. The Proptype declaration for Message is included in types/shapes.js, i.e. to use it:

import { Message } from '@precor/web-api-bridge/types/shapes';

Documentation

WebApiBridge Class

Examples

react-iframe is a simple react implementation of an API between a parent and an iframe.

react-multi is a react implementation of an API between a parent and multiple iframes.

webapp-library extends the react-multi example by creating a functional library abstraction over the bridge for the web app iframes. It also demonstrates mulitiple apis per window and dynamic additions of apis after the iframe based web apps are loaded.

react-native is a simple react implementation of an API between a react-native application and a web application loaded as a webview.

Gotchas

  • If you need to send a message from an app that loads a webview or an iframe, e.g. from a React Native app or a window parent, before receiving from that app then wait for the load to complete, e.g. onLoad callback to send that initial message.