Skip to content

Latest commit

 

History

History
891 lines (562 loc) · 31 KB

README.md

File metadata and controls

891 lines (562 loc) · 31 KB

@rescript-react-native/webview

Build Status Version ReScript Forum

ReScript bindings for react-native-webview.

Exposed as the ReactNativeWebView module.

@rescript-react-native/webview X.y.* means it's compatible with @react-native-community/react-native-webview X.y.*

Installation

When react-native-webview is properly installed & configured by following their installation instructions, you can install the bindings:

npm install @rescript-react-native/webview
# or
yarn add @rescript-react-native/webview

@rescript-react-native/webview should be added to bs-dependencies in your bsconfig.json. For example,

{
  //...
  "bs-dependencies": [
    "@rescript/react",
    "rescript-react-native",
    // ...
+    "@rescript-react-native/webview"
  ],
  //...
}

Usage

Types

DataDetectorTypes.t

Valid values are:

DataDetectorTypes.phoneNumberDataDetectorTypes.linkDataDetectorTypes.addressDataDetectorTypes.calendarEventDataDetectorTypes.noneDataDetectorTypes.allDataDetectorTypes.trackingNumberDataDetectorTypes.flightNumberDataDetectorTypes.lookupSuggestion

DecelerationRate.t

Values may be created using DecelerationRate.value

value: float => t

Other valid values are DecelerationRate.normal and DecelerationRate.fast which are equivalent to specifying 0.998 and 0.99 and match the underlying iOS settings for UIScrollViewDecelerationRateNormal and UIScrollViewDecelerationRateFast respectively.

NavigationType.t

Valid values are:

NavigationType.clickNavigationType.formsubmitNavigationType.backforwardNavigationType.reloadNavigationType.formresubmitNavigationType.other

Source.t

Source to be loaded in the WebView, as specified by the [source(#source-source.t) prop can be either a URI or static HTML.

Source.uri

Creates a URI source

uri:
    (
      ~uri: string=?,
      ~method: [
                 | `CONNECT
                 | `DELETE
                 | `GET
                 | `HEAD
                 | `OPTIONS
                 | `PATCH
                 | `POST
                 | `PUT
                 | `TRACE
               ]
                 =?,
      ~headers: Js.t('a)=?,
      ~body: string=?,
      unit
    ) =>
    t
  • uri specifies the URI (local or remote) to load in the WebView.
  • method specifies HTTP Method to use, defaults to `GET. Only `GET and `POST are supported on Android.
  • headers specifies additional HTTP headers to send with the request. This can only be used with `GET requests on Android.
  • body specifies HTTP body to send with the request. This must be a valid UTF-8 string, and will be sent exactly as specified, with no additional encoding (e.g. URL-escaping or base64) applied. This can only be used with `POST requests on Android.
Source.html

Creates a static HTML source

html: (~html: string=?, ~baseUrl: string=?, unit) => t
  • html specifies static HTML to display in the WebView as string.
  • baseUrl specifies the base URL to be used for any relative links in the HTML. It is also used for the origin header with CORS requests made from the WebView. Refer to Android WebView Docs.

UnionCallback.t

Type of function passed to the onLoadEnd prop, to handle the union type webViewNavigationOrError. Defined as

ReactNative.Event.syntheticEvent(Js.t(webViewNavigationOrError)) => unit
UnionCallback.make

Creates a function of type UnionCallback.t

make:
  (
    ~navigationCallback: WebViewNavigationEvent.t => unit,
    ~errorCallback: WebViewErrorEvent.t => unit
  ) =>
  t;
UnionCallback.uncurriedMake

Creates a function of type UnionCallback.t

uncurriedMake:
  (
    ~navigationCallback:(. webViewNavigationEvent) => unit,
    ~errorCallback:(. webViewErrorEvent) => unit
  ) =>
  t;

element

Represents a WebView instance, to be used with methods.

nativeConfig

Should be constructed as below:

nativeConfig:
  (
    ~component: React.component('a)=?,
    ~props: Js.t('b)=?,
    ~viewManager: Js.t('c)=?
  ) =>
  nativeConfig

You may refer to iOS↗ and Android↗ specific guides on how to create a custom WebView.

ref

React ref intended to access a WebView instance. Defined as

type ref = React.Ref.t(Js.nullable(element))

Js.t(webViewNativeEvent)

Has the below keys, which can be accessed with ##.

  • target: ReactNative.NativeTypes.nodeHandle
  • url: string
  • title: string
  • loading: bool
  • canGoBack: bool
  • canGoForward: bool

Js.t(webViewError)

Has the below keys, which can be accessed with ##.

  • target: ReactNative.NativeTypes.nodeHandle
  • url: string
  • title: string
  • loading: bool
  • canGoBack: bool
  • canGoForward: bool
  • description: string
  • domain: option(string)
  • code: int
  • didFailProvisionalNavigation: option(bool)

Note: domain key only exists on iOS

Js.t(webViewHttpError)

Has the below keys, which can be accessed with ##.

  • target: ReactNative.NativeTypes.nodeHandle
  • url: string
  • title: string
  • loading: bool
  • canGoBack: bool
  • canGoForward: bool
  • description: string
  • statusCode: int

Note: description key only exists on iOS

Js.t(webViewMessage)

Has the below keys, which can be accessed with ##.

  • target: ReactNative.NativeTypes.nodeHandle
  • url: string
  • title: string
  • loading: bool
  • canGoBack: bool
  • canGoForward: bool
  • data: string

Js.t(webViewNativeProgressEvent)

Has the below keys, which can be accessed with ##.

  • target: ReactNative.NativeTypes.nodeHandle
  • url: string
  • title: string
  • loading: bool
  • canGoBack: bool
  • canGoForward: bool
  • progress: float

Js.t(webViewNavigation)

Has the below keys, which can be accessed with ##.

  • target: ReactNative.NativeTypes.nodeHandle
  • url: string
  • title: string
  • loading: bool
  • canGoBack: bool
  • canGoForward: bool
  • navigationType: ReactNativeWebView_NavigationType.t
  • mainDocumentURL: option(string)

Js.t(webViewShouldStartLoadWithRequest)

Has the below keys, which can be accessed with ##.

  • target: ReactNative.NativeTypes.nodeHandle
  • url: string
  • title: string
  • loading: bool
  • canGoBack: bool
  • canGoForward: bool
  • navigationType: ReactNativeWebView_NavigationType.t
  • mainDocumentURL: option(string)
  • lockIdentifier: int

webViewErrorEvent

wraps Js.t(webViewError) in ReactNative.Event.syntheticEvent

type WebViewErrorEvent.t =
  ReactNative.Event.syntheticEvent(Js.t(webViewError));

passed to the handler specified for onError

webViewHttpErrorEvent

wraps Js.t(webViewHttpError) in ReactNative.Event.syntheticEvent

type WebViewHttpErrorEvent.t =
  ReactNative.Event.syntheticEvent(Js.t(webViewHttpError));

passed to the handler specified for onHttpError

webViewMessageEvent

wraps Js.t(webViewMessage) in ReactNative.Event.syntheticEvent

type WebViewMessageEvent.t =
  ReactNative.Event.syntheticEvent(Js.t(webViewMessage));

passed to the handler specified for onMessage

webViewNavigationEvent

wraps Js.t(webViewNavigation) in ReactNative.Event.syntheticEvent

type WebViewNavigationEvent.t =
  ReactNative.Event.syntheticEvent(Js.t(webViewNavigation));

passed to handlers specified for onLoad or onLoadStart

webViewProgressEvent

wraps Js.t(webViewNativeProgressEvent) in ReactNative.Event.syntheticEvent

type WebViewProgressEvent.t =
  ReactNative.Event.syntheticEvent(Js.t(webViewNativeProgressEvent));

passed to the handler specified for onLoadProgress

webViewTerminatedEvent

wraps Js.t(webViewNativeEvent) in ReactNative.Event.syntheticEvent

type WebViewTerminatedEvent.t =
  ReactNative.Event.syntheticEvent(webViewNativeEvent);

passed to the handler specified for onContentProcessDidTerminate

webViewNavigationOrError

Union type passed to the handler specified for onLoadEnd, is of type webViewNavigationEvent if loading succeeds and webViewErrorEvent if it fails.

Refer to UnionCallback.t for information on how to create the appropriate handler.

Props

ref: ref

Should be specified to be able to access the WebView instance and apply methods. Also refer to element and ref.

As an alternative, refer to React documentation on forwardRef.

allowingReadAccessToURL: string

Specifies URLs which can be referenced in scripts, AJAX requests and CSS imports. Used only for URIs specified as file://. Defaults to the URL provided in the URI.

allowFileAccess: bool

Allows access to the file system via URI specified as file:// when true, defaults to false.

allowUniversalAccessFromFileURLs: bool

JavaScript running in the context of a file scheme URL should be allowed access to content from any origin including content from other file scheme URLs when true, defaults to false.

allowsBackForwardNavigationGestures: bool

iOS only

Horizontal swipe gestures are allowed when true, defaults to false.

allowsFullscreenVideo: bool

Fullscreen playback of videos is allowed when true, defaults to false.

allowsInlineMediaPlayback: bool

Determines whether HTML5 videos play inline or use the native full-screen controller, defaults false.

allowsLinkPreview: bool

iOS only required 3D Touch support

Pressing on a link displays a preview of the target when true. Defaults to true on iOS 10 and later, to false otherwise.

androidHardwareAccelerationDisabled: bool

Android only

Disables Hardware Acceleration in the WebView when true, defaults to false.

androidLayerType: [ | `none | `software | `hardware ]

Android only

Specifies the layer type.

applicationNameForUserAgent: string

Specifies string value to append to the User-Agent header, will be overridden if userAgent is set.

For example when applicationNameForUserAgent="DemoApp/1.1.0" as below:

<ReactNativeWebView
  source=ReactNativeWebView.Source.uri(~uri="https://facebook.github.io/react-native", ())
  applicationNameForUserAgent="DemoApp/1.1.0"
/>

Resulting User-Agent may be as below:

Android
Mozilla/5.0 (Linux; Android 8.1.0; Android SDK built for x86 Build/OSM1.180201.021; wv) AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 Chrome/61.0.3163.98 Mobile Safari/537.36 DemoApp/1.1.0
iOS
Mozilla/5.0 (iPhone; CPU iPhone OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Mobile/15E148 DemoApp/1.1.0

automaticallyAdjustContentInsets: bool

Controls whether to adjust the content inset for web views that are placed behind a navigation bar, tab bar, or toolbar. The default value is true.

bounces: bool

WebView bounces as edge of the content is reached when true, defaults to true.

cacheEnabled: bool

Sets whether WebView should use browser caching, defaults to true.

cacheEnabled: [ | `default | `cacheOnly | `cacheElseNetwork | `noCache ]

Overrides default caching behavior, which depends on the navigation type. For a normal page load, cache is checked and content is revalidated as needed. When navigating back, content is not revalidated, but simply retrieved from the cache.

Value Behavior
`default Default cache usage mode. If the navigation type doesn't impose any specific behavior, use cached resources when they are available and not expired, otherwise load resources from the network.
`cacheOnly Don't use the network, load resources from the cache.
`cacheElseNetwork Use cached resources when available, even when expired. Otherwise, load resources from the network.
`noCache Don't use the cache, load resources from the network.

containerStyle: ReactNative.Style.t

allows to customize the WebView container style. Please note that there are default styles (example: ~flex=0. needs to be specified to use the height prop).

contentInset: ReactNative.View.edgeInsets

Refer to rescript-react-native documentation on View.

contentInsetAdjustmentBehavior: [ | `never | `always | `automatic | `scrollableAxes]

iOS only

Specifies how safe area insets are used to modify content area of the scroll view, defaults to `never. Available on iOS 11 and later.

contentMode: [ | `recommended | `mobile | `desktop]

iOS only

Controls the type of content to load. Available on iOS 13 and later. Defaults to recommended, which loads mobile content on iPhone & iPad Mini but desktop content on larger iPads.

More at https://github.com/react-native-webview/react-native-webview/blob/master/docs/Reference.md#contentMode

dataDetectorTypes: array(DataDetectorTypes.t)

Specifies types of data to be converted to clickable URLs in content of the WebView, defaults to [|DataDetectorTypes.phoneNumber|]. Refer to DataDetectorTypes.t for all valid values.

decelerationRate: DecelerationRate.t

iOS only

Specifies how quickly the scroll view should decelerate once the user lifts their finger, defaults to DecelerationRate.fast. Refer to DecelerationRate.t for all valid values.

directionalLockEnabled: bool

iOS only

Disables scrolling in a particular direction when true, defaults to true.

domStorageEnabled: bool

Android only

DOM Storage is enabled when true.

geolocationEnabled: bool

Android only

Set whether geolocation is enabled in the WebView, defaults to false.

hideKeyboardAccessoryView: bool

iOS only

Keyboard accessory view will be hidden when true.

incognito: bool

Does not store any data within the lifetime of the WebView.

injectedJavaScript: string

Specifies JavaScript that will be injected into the web page when loaded. The string should evaluate to a valid type (e.g. true) and not otherwise throw an exception.

Example below passeswindow.location as a JSON object to be handled by the function passed to onMessage

let injectedJavaScript = "(function() {
  window.ReactNativeWebView.postMessage(JSON.stringify(window.location));
})();";

<ReactNativeWebView
  source=ReactNativeWebView.Source.uri(~uri="https://facebook.github.io/react-native", ())
  injectedJavaScript=injectedJavaScript
  onMessage={e => Js.Console.warn(e##nativeEvent##data)}
/>

Note that the JavaScript will only be run once when the page is loaded for the first time; it will not be run again even if the page is reloaded or navigated away.

Refer to the Communicating between JS and Native guide for more information.

On iOS, also refer to documentation on WKUserScriptInjectionTimeAtDocumentEnd.

injectedJavaScriptForMainFrameOnly: bool

iOS only Script specified with injectedJavaScript will be loaded for all frames (main frame and iframes) when false, defaults to true (only for the main frame).

injectedJavaScriptBeforeContentLoaded: string

Specifies JavaScript that will be injected into the web page after the document element is created, but before any other content is loaded. The string should evaluate to a valid type (e.g. true) and not otherwise throw an exception.

Example below passeswindow.location as a JSON object to be handled by the function passed to onMessage

let injectedJavaScript = "(function() {
  window.ReactNativeWebView.postMessage(JSON.stringify(window.location));
})();";

<ReactNativeWebView
  source=ReactNativeWebView.Source.uri(~uri="https://facebook.github.io/react-native", ())
  injectedJavaScriptBeforeContentLoaded=injectedJavaScript
  onMessage={e => Js.Console.warn(e##nativeEvent##data)}
/>

Refer to the Communicating between JS and Native guide for more information.

Also refer to documentation on WKUserScriptInjectionTimeAtDocumentStart.

injectedJavaScriptBeforeContentLoadedForMainFrameOnly: bool

iOS only Script specified with injectedJavaScriptBeforeContentLoaded will be loaded for all frames (main frame and iframes) when false, defaults to true (only for the main frame).

Note that it may not be possible to inject JS into iframes in this stage of the page lifecycle, therefore exercise caution when setting to false.

javaScriptCanOpenWindowsAutomatically: bool

A Boolean value indicating whether JavaScript can open windows without user interaction. The default value is false.

javaScriptEnabled: bool

Android only

Enables JavaScript in the WebView when true, defaults to true. JavaScript is already enabled by default on iOS.

keyboardDisplayRequiresUserAction: bool

iOS only

Web content can programmatically display the keyboard when false, defaults to true.

mediaPlaybackRequiresUserAction: bool

HTML5 audio and video playback requires the user to tap them when true, defaults to true.

Some videos may hang while loading on iOS when true. As the props defaults to true, setting mediaPlaybackRequiresUserAction=false may fix this issue.

mixedContentMode: [@bs.string] [ | `never | `always | `compatibility]

Android only

Specifies mixed content mode, defaults to `never.

Value Behavior
`never WebView will not allow a secure origin to load content from an insecure origin.
`always WebView will allow a secure origin to load content from any other (even insecure) origin.
`compatibility WebView will attempt to be compatible with how modern web browsers treat mixed content.

nativeConfig: nativeConfig

Overrides the native component used to render the WebView. Enables a custom native WebView which uses the same JavaScript as the original WebView. Refer to the nativeConfig type on how to specify the custom component.

You may refer to iOS- and Android-specific guides on how to create a custom WebView.

onContentProcessDidTerminate: WebViewTerminatedEvent.t => unit

iOS only

Specifies function to be invoked when the WebView content process is terminated. The process may be terminated due to reasons such as running too long or using too many resources, however, once terminated a blank page is displayed and the WebView becomes unusable. Please refer to the PR which added the functionality to allow handling this issue.

<ReactNativeWebView
  source=ReactNativeWebView.Source.uri(~uri="https://facebook.github.io/react-native", ())
  onContentProcessDidTerminate={_ =>
    ReactNativeWebView.reload()

    this.refs.webview.reload();
  }}
/>

onFileDownload: WebViewDownloadEvent.t => unit

iOS only

Specifies function to be invoked when the WebView is about to download a file.

More at https://github.com/react-native-webview/react-native-webview/blob/master/docs/Reference.md#onFileDownload

onError: WebViewErrorEvent.t => unit

Specifies function to be invoked when the WebView fails to load.

onLoad: WebViewNavigationEvent.t => unit

Specifies function to be invoked when the WebView has finished loading.

onLoadEnd: UnionCallback.t

Specifies function to be invoked when the WebView succeeds or fails to load.

onLoadProgress: WebViewProgressEvent.t => unit

Specifies function to be invoked while the WebView is loading.

onLoadStart: WebViewNavigationEvent.t => unit

Specifies function to be invoked when the WebView starts to load.

onMessage: WebViewMessageEvent.t => unit

Specifies function to be invoked when the WebView calls window.ReactNativeWebView.postMessage. Setting this prop will inject that global into the webview.

window.ReactNativeWebView.postMessage accepts one string argument, which will be available as e.g. e##nativeEvent##data where e is the event object.

Refer to the Communicating between JS and Native guide for more information.

onNavigationStateChange: Js.t(webViewNavigation) => unit

Specifies function to be invoked when the WebView starts or ends loading.

Note that this method will not be invoked on hash URL changes (e.g. from https://example.com/users#list to https://example.com/users#help). A workaround may be found in the Guide.

onRenderProcessGone: WebViewRenderProcessGone.t => unit

Android only Function that is invoked when the WebView process crashes or is killed by the OS.

More at https://github.com/react-native-webview/react-native-webview/blob/master/docs/Reference.md#onRenderProcessGone

onShouldStartLoadWithRequest: Js.t(webViewShouldStartLoadWithRequest) => bool

Allows custom handling of any WebView requests. Specified function should return true to allow requests and false to stop loading.

On Android, the function is not called on first load.

originWhitelist: array(string)

Specifies array(string) listing origin strings to which navigation is allowed. Strings will be matched against just the origin (not the full URL) and wildcards are allowed. Any URL not whitelisted will be handled by the OS. Defaults to [|"http://", "https://"|].

overScrollMode: [ | `never | `always | `content]

Android only

Specifies the over scroll mode, defaults to `always.

Value Behavior
`always Always allow a user to over-scroll the view if scrollable
`never Never allow a user to over-scroll the view
`content Allow a user to over-scroll the view only if scrollable and the content is large enough

pagingEnabled: bool

iOS only

As the user scrolls, scroll view stops on multiples of the its bounds when true, defaults to false.

pullToRefreshEnabled: bool

iOS only

Boolean value that determines whether a pull to refresh gesture is available in the WebView. The default value is false. If true, sets bounces automatically to true.

More at https://github.com/react-native-webview/react-native-webview/blob/master/docs/Reference.md#pullToRefreshEnabled

renderError: string => React.element

Specifies a function to be invoked when there is an error.

<ReactNativeWebView
  source=ReactNativeWebView.Source.uri(~uri="https://facebook.github.io/react-native", ())
  renderError={errorName => <Error name=errorName />}
/>

renderLoading: unit => React.element

Specifies a function to be invoked when the WebView is loading. Requires setting startInLoadingState=true .

<ReactNativeWebView
  source=ReactNativeWebView.Source.uri(~uri="https://facebook.github.io/react-native", ())
  startInLoadingState=true
  renderLoading={() => <Loading />}
/>

saveFormDataDisabled: bool

Android only

bool determines whether the WebView should disable saving form data., defaults to false. Has no effect on Android API level 26 and abovem as there is an Autofill feature storing form data.

scalesPageToFit: bool

Android only

Web content is scaled to fit the view and the user may change the scale when true, defaults to true.

scrollEnabled: bool

iOS only

Enables scrolling in the WebView, defaults to true. When false, document body will not be moved if the keyboard obstructs an input.

sharedCookiesEnabled: bool

iOS only

When set true, shared cookies from [NSHTTPCookieStorage sharedHTTPCookieStorage] should be used for every load request in the WebView, defaults to false.

showsHorizontalScrollIndicator: bool

Horizontal scroll indicator is shown in the WebView when true, defaults to true.

showsVerticalScrollIndicator: bool

Vertical scroll indicator is shown in the WebView when true, defaults to true.

source: Source.t

Specifies the resource to be loaded in the WebView as static HTML or a URI (with optional headers). Note that setting originWhitelist to [|"*"|] is required when source is some static HTML. Refer to Source.t for information on how to create the appropriate type.

startInLoadingState: bool

Forces the WebView to show the loading view on first load; must be set to true for the renderLoading prop to work.

textZoom: float

Android only

Resolves issue where custom font sizes on Android leads to undesirable scaling of the interface when set to 100.0 (i.e. textZoom=100.0).

ignoreSilentHardwareSwitch: bool

iOS only

When set to true the hardware silent switch is ignored. Default: false

thirdPartyCookiesEnabled: bool

Enables third party cookies in WebView when true, defaults to true on iOS and Android versions below 5.0.

userAgent: string

Specifies User-Agent header for the WebView

View props

Refer to rescript-react-native documentation.

Please do note the below:

style: ReactNative.Style.t

allows to customize the WebView style. Please note that there are default styles (example: ~flex=0. needs to be specified to use the height prop).

Methods

For the methods below, element representing the WebView instance needs to be determined from the ref which itself can be defined and passed to the WebView ref prop as below:

let ref = React.createRef();

<ReactNativeWebView
  ref=ref

The element can be determined and the method reload may be called as below:

switch (ref -> React.Ref.current -> Js.Nullable.toOption) {
| None => Js.Console.warn("no element")
| Some(e) => ReactNativeWebView.reload(e)
};

clearFormData: element => unit

Android only Removes the autocomplete popup (if present) from the currently focused form field.

clearCache: element => unit

Android only Clears the resource cache for all WebViews in the application.

clearHistory: element => unit

Android only Clears WebView's internal back/forward list

requestFocus: element => unit

Request focus for the WebView.

goBack: element => unit

Navigates back one page in the WebView history.

goForward: element => unit

Navigates forward one page in the WebView history.

reload: element => unit

Reloads the current page.

stopLoading: element => unit

Stop loading the current page.

injectJavaScript: (element, string) => unit

Injects JavaScript as string into the web page. The string should evaluate to a valid type (e.g. true) and not otherwise throw an exception.

Refer to the Communicating between JS and Native guide for more information.


Changelog

Check the changelog for more information about recent releases.

Contribute

Read the contribution guidelines before contributing.

Code of Conduct

We want this community to be friendly and respectful to each other. Please read our full code of conduct so that you can understand what actions will and will not be tolerated.