cordova-plugin-inappbrowser
Advanced tools
Comparing version 3.2.0 to 4.0.0
@@ -28,3 +28,3 @@ <!-- | ||
contribute code. | ||
For instructions on this, start with the | ||
@@ -34,4 +34,3 @@ [contribution overview](http://cordova.apache.org/contribute/). | ||
The details are explained there, but the important items are: | ||
- Sign and submit an Apache ICLA (Contributor License Agreement). | ||
- Have a Jira issue open that corresponds to your contribution. | ||
- Check for Github issues that corresponds to your contribution and link or create them if necessary. | ||
- Run the tests so your patch doesn't break existing functionality. | ||
@@ -41,27 +40,1 @@ | ||
The notes on [Commit Workflow](https://github.com/apache/cordova-coho/blob/master/docs/committer-workflow.md#commit-workflow) can be helpful even if you are not a committer. | ||
## Running plugin tests | ||
* clone and install [cordova-plugin-test-framework](https://github.com/apache/cordova-plugin-test-framework) | ||
``` | ||
git clone git@github.com:apache/cordova-plugin-test-framework.git | ||
``` | ||
* edit ```cordova-plugin-test-framework/www/assets/index.html``` and add the following line | ||
``` | ||
<meta http-equiv="Content-Security-Policy" content="default-src 'self' data: gap: https://ssl.gstatic.com http://cordova.apache.org http://google.co.uk https://google.co.uk 'unsafe-eval'; style-src 'self' 'unsafe-inline'; media-src *"> | ||
``` | ||
* create test project | ||
``` | ||
cordova create plugintest | ||
cd plugintest | ||
cordova platform add android | ||
cordova plugin add ../cordova-plugin-inappbrowser | ||
cordova plugin add ../cordova-plugin-inappbrowser/tests | ||
cordova plugin add ../cordova-plugin-test-framework | ||
``` | ||
* edit ```config.xml``` and replace ```<content src="index.html" />``` with ```<content src="cdvtests/index.html" />``` | ||
* run application | ||
``` | ||
cordova run | ||
``` |
{ | ||
"name": "cordova-plugin-inappbrowser", | ||
"version": "3.2.0", | ||
"version": "4.0.0", | ||
"description": "Cordova InAppBrowser Plugin", | ||
@@ -46,2 +46,6 @@ "types": "./types/index.d.ts", | ||
"4.0.0": { | ||
"cordova": ">=3.1.0", | ||
"cordova-ios": ">=4.0.0" | ||
}, | ||
"5.0.0": { | ||
"cordova": ">100" | ||
@@ -48,0 +52,0 @@ } |
@@ -46,2 +46,6 @@ --- | ||
If you change the browsers `window.open` function this way, it can have unintended side | ||
effects (especially if this plugin is included only as a dependency of another | ||
plugin). | ||
The InAppBrowser window behaves like a standard web browser, | ||
@@ -56,18 +60,2 @@ and can't access Cordova APIs. For this reason, the InAppBrowser is recommended | ||
For backwards compatibility, this plugin also hooks `window.open`. | ||
However, the plugin-installed hook of `window.open` can have unintended side | ||
effects (especially if this plugin is included only as a dependency of another | ||
plugin). The hook of `window.open` will be removed in a future major release. | ||
Until the hook is removed from the plugin, apps can manually restore the default | ||
behaviour: | ||
delete window.open // Reverts the call back to its prototype's default | ||
Although `window.open` is in the global scope, InAppBrowser is not available until after the `deviceready` event. | ||
document.addEventListener("deviceready", onDeviceReady, false); | ||
function onDeviceReady() { | ||
console.log("window.open works well"); | ||
} | ||
## Installation | ||
@@ -128,3 +116,3 @@ | ||
- __toolbarcolor__: set to a valid hex color string, for example: `#00ff00`, and it will change the color the toolbar from default. Only has effect if user has location set to `yes`. | ||
- __lefttoright__: Set to `yes` to swap positions of the navigation buttons and the close button. Specifically, navigation buttons go to the left and close button to the right. | ||
- __lefttoright__: Set to `yes` to swap positions of the navigation buttons and the close button. Specifically, navigation buttons go to the right and close button to the left. Default value is `no`. | ||
- __zoom__: set to `yes` to show Android browser's zoom controls, set to `no` to hide them. Default value is `yes`. | ||
@@ -134,6 +122,6 @@ - __mediaPlaybackRequiresUserAction__: Set to `yes` to prevent HTML5 audio or video from autoplaying (defaults to `no`). | ||
- __useWideViewPort__: Sets whether the WebView should enable support for the "viewport" HTML meta tag or should use a wide viewport. When the value of the setting is `no`, the layout width is always set to the width of the WebView control in device-independent (CSS) pixels. When the value is `yes` and the page contains the viewport meta tag, the value of the width specified in the tag is used. If the page does not contain the tag or does not provide a width, then a wide viewport will be used. (defaults to `yes`). | ||
- __fullscreen__: Sets whether the InappBrowser WebView is displayed fullscreen or not. In fullscreen mode, the status bar is hidden. Default value is `yes`. | ||
iOS supports these additional options: | ||
- __usewkwebview__: set to `yes` to use WKWebView engine for the InappBrowser. Omit or set to `no` (default) to use UIWebView. Note: Using `usewkwebview=yes` requires that a WKWebView engine plugin be installed in the Cordova project (e.g. [cordova-plugin-wkwebview-engine](https://github.com/apache/cordova-plugin-wkwebview-engine) or [cordova-plugin-ionic-webview](https://github.com/ionic-team/cordova-plugin-ionic-webview)). | ||
- __hidden__: set to `yes` to create the browser and load the page, but not show it. The loadstop event fires when loading is complete. Omit or set to `no` (default) to have the browser open and load normally. | ||
@@ -146,3 +134,3 @@ - __beforeload__: set to enable the `beforeload` event to modify which pages are actually loaded in the browser. Accepted values are `get` to intercept only GET requests, `post` to intercept on POST requests or `yes` to intercept both GET & POST requests. Note that POST requests are not currently supported and will be ignored (if you set `beforeload=post` it will raise an error). | ||
- __closebuttoncaption__: set to a string to use as the __Done__ button's caption. Note that you need to localize this value yourself. | ||
- __disallowoverscroll__: Set to `yes` or `no` (default is `no`). Turns on/off the UIWebViewBounce property. | ||
- __disallowoverscroll__: Set to `yes` or `no` (default is `no`). Turns on/off the the bounce of the WKWebView's UIScrollView. | ||
- __hidenavigationbuttons__: set to `yes` or `no` to turn the toolbar navigation buttons on or off (defaults to `no`). Only applicable if toolbar is not disabled. | ||
@@ -154,9 +142,7 @@ - __navigationbuttoncolor__: set as a valid hex color string, for example: `#00ff00`, to change from the default color. Only applicable if navigation buttons are visible. | ||
- __lefttoright__: Set to `yes` to swap positions of the navigation buttons and the close button. Specifically, close button goes to the right and navigation buttons to the left. | ||
- __enableViewportScale__: Set to `yes` or `no` to prevent viewport scaling through a meta tag (defaults to `no`). Only applicable to UIWebView (`usewkwebview=no`) and WKWebView (`usewkwebview=yes`) on iOS 10+. | ||
- __mediaPlaybackRequiresUserAction__: Set to `yes` to prevent HTML5 audio or video from autoplaying (defaults to `no`). Applicable to UIWebView (`usewkwebview=no`) and WKWebView (`usewkwebview=yes`). | ||
- __allowInlineMediaPlayback__: Set to `yes` or `no` to allow in-line HTML5 media playback, displaying within the browser window rather than a device-specific playback interface. The HTML's `video` element must also include the `webkit-playsinline` attribute (defaults to `no`). Applicable to UIWebView (`usewkwebview=no`) and WKWebView (`usewkwebview=yes`). | ||
- __keyboardDisplayRequiresUserAction__: Set to `yes` or `no` to open the keyboard when form elements receive focus via JavaScript's `focus()` call (defaults to `yes`). Only applicable to UIWebView (`usewkwebview=no`). | ||
- __suppressesIncrementalRendering__: Set to `yes` or `no` to wait until all new view content is received before being rendered (defaults to `no`). Only applicable to UIWebView (`usewkwebview=no`). | ||
- __presentationstyle__: Set to `pagesheet`, `formsheet` or `fullscreen` to set the [presentation style](http://developer.apple.com/library/ios/documentation/UIKit/Reference/UIViewController_Class/Reference/Reference.html#//apple_ref/occ/instp/UIViewController/modalPresentationStyle) (defaults to `fullscreen`). | ||
- __transitionstyle__: Set to `fliphorizontal`, `crossdissolve` or `coververtical` to set the [transition style](http://developer.apple.com/library/ios/#documentation/UIKit/Reference/UIViewController_Class/Reference/Reference.html#//apple_ref/occ/instp/UIViewController/modalTransitionStyle) (defaults to `coververtical`). | ||
- __enableViewportScale__: Set to `yes` or `no` to prevent viewport scaling through a meta tag (defaults to `no`). | ||
- __mediaPlaybackRequiresUserAction__: Set to `yes` to prevent HTML5 audio or video from autoplaying (defaults to `no`). | ||
- __allowInlineMediaPlayback__: Set to `yes` or `no` to allow in-line HTML5 media playback, displaying within the browser window rather than a device-specific playback interface. The HTML's `video` element must also include the `webkit-playsinline` attribute (defaults to `no`). | ||
- __presentationstyle__: Set to `pagesheet`, `formsheet` or `fullscreen` to set the [presentation style](https://developer.apple.com/documentation/uikit/uimodalpresentationstyle) (defaults to `fullscreen`). | ||
- __transitionstyle__: Set to `fliphorizontal`, `crossdissolve` or `coververtical` to set the [transition style](https://developer.apple.com/documentation/uikit/uimodaltransitionstyle) (defaults to `coververtical`). | ||
- __toolbarposition__: Set to `top` or `bottom` (default is `bottom`). Causes the toolbar to be at the top or bottom of the window. | ||
@@ -163,0 +149,0 @@ - __hidespinner__: Set to `yes` or `no` to change the visibility of the loading indicator (defaults to `no`). |
@@ -9,3 +9,3 @@ // Type definitions for Apache Cordova InAppBrowser plugin | ||
// TypeScript Version: 2.3 | ||
type channel = "loadstart" | "loadstop" | "loaderror" | "exit" | "message"; | ||
type channel = "loadstart" | "loadstop" | "loaderror" | "exit" | "message" | "customscheme"; | ||
@@ -44,2 +44,9 @@ interface Window { | ||
addEventListener(type: channel, callback: InAppBrowserEventListenerOrEventListenerObject): void; | ||
/** | ||
* Adds a listener for an event from the InAppBrowser. | ||
* @param type any custom event that might occur. | ||
* @param callback the function that executes when the event fires. The function is | ||
* passed an InAppBrowserEvent object as a parameter. | ||
*/ | ||
addEventListener(type: string, callback: InAppBrowserEventListenerOrEventListenerObject): void; | ||
// removeEventListener overloads | ||
@@ -46,0 +53,0 @@ /** |
@@ -23,8 +23,2 @@ /* | ||
(function () { | ||
// special patch to correctly work on Ripple emulator (CB-9760) | ||
if (window.parent && !!window.parent.ripple) { // https://gist.github.com/triceam/4658021 | ||
module.exports = window.open.bind(window); // fallback to default window.open behaviour | ||
return; | ||
} | ||
var exec = require('cordova/exec'); | ||
@@ -31,0 +25,0 @@ var channel = require('cordova/channel'); |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is too big to display
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
New author
Supply chain riskA new npm collaborator published a version of the package for the first time. New collaborators are usually benign additions to a project, but do indicate a change to the security surface area of a package.
Found 1 instance in 1 package
0
317540
37
849
704