@capgo/inappbrowser 1.2.20 → 1.3.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +22 -3
- package/android/src/main/java/ee/forgr/capacitor_inappbrowser/InAppBrowserPlugin.java +27 -0
- package/android/src/main/java/ee/forgr/capacitor_inappbrowser/WebViewDialog.java +10 -0
- package/dist/docs.json +48 -1
- package/dist/esm/definitions.d.ts +20 -1
- package/dist/esm/definitions.js.map +1 -1
- package/dist/esm/web.d.ts +3 -0
- package/dist/esm/web.js +4 -0
- package/dist/esm/web.js.map +1 -1
- package/dist/plugin.cjs.js +4 -0
- package/dist/plugin.cjs.js.map +1 -1
- package/dist/plugin.js +4 -0
- package/dist/plugin.js.map +1 -1
- package/ios/Plugin/InAppBrowserPlugin.swift +22 -5
- package/ios/Plugin/WKWebViewController.swift +11 -5
- package/package.json +1 -1
package/README.md
CHANGED
|
@@ -38,6 +38,7 @@ Then the permission will be asked when the camera is used.
|
|
|
38
38
|
* [`getCookies(...)`](#getcookies)
|
|
39
39
|
* [`close()`](#close)
|
|
40
40
|
* [`openWebView(...)`](#openwebview)
|
|
41
|
+
* [`executeScript(...)`](#executescript)
|
|
41
42
|
* [`setUrl(...)`](#seturl)
|
|
42
43
|
* [`addListener('urlChangeEvent', ...)`](#addlistenerurlchangeevent)
|
|
43
44
|
* [`addListener('closeEvent', ...)`](#addlistenercloseevent)
|
|
@@ -138,6 +139,21 @@ Open url in a new webview with toolbars
|
|
|
138
139
|
--------------------
|
|
139
140
|
|
|
140
141
|
|
|
142
|
+
### executeScript(...)
|
|
143
|
+
|
|
144
|
+
```typescript
|
|
145
|
+
executeScript({ code }: { code: string; }) => Promise<void>
|
|
146
|
+
```
|
|
147
|
+
|
|
148
|
+
Injects JavaScript code into the InAppBrowser window.
|
|
149
|
+
|
|
150
|
+
| Param | Type |
|
|
151
|
+
| --------- | ------------------------------ |
|
|
152
|
+
| **`__0`** | <code>{ code: string; }</code> |
|
|
153
|
+
|
|
154
|
+
--------------------
|
|
155
|
+
|
|
156
|
+
|
|
141
157
|
### setUrl(...)
|
|
142
158
|
|
|
143
159
|
```typescript
|
|
@@ -259,9 +275,10 @@ Reload the current web page.
|
|
|
259
275
|
|
|
260
276
|
#### ClearCookieOptions
|
|
261
277
|
|
|
262
|
-
| Prop
|
|
263
|
-
|
|
|
264
|
-
| **`url`**
|
|
278
|
+
| Prop | Type |
|
|
279
|
+
| ----------- | -------------------- |
|
|
280
|
+
| **`url`** | <code>string</code> |
|
|
281
|
+
| **`cache`** | <code>boolean</code> |
|
|
265
282
|
|
|
266
283
|
|
|
267
284
|
#### HttpCookie
|
|
@@ -293,6 +310,8 @@ Reload the current web page.
|
|
|
293
310
|
| **`title`** | <code>string</code> | Title of the browser | <code>'New Window'</code> | 0.1.0 |
|
|
294
311
|
| **`backgroundColor`** | <code><a href="#backgroundcolor">BackgroundColor</a></code> | Background color of the browser, only on IOS | <code>BackgroundColor.BLACK</code> | 0.1.0 |
|
|
295
312
|
| **`isPresentAfterPageLoad`** | <code>boolean</code> | Open url in a new window fullscreen isPresentAfterPageLoad: if true, the browser will be presented after the page is loaded, if false, the browser will be presented immediately. | <code>false</code> | 0.1.0 |
|
|
313
|
+
| **`isInspectable`** | <code>boolean</code> | Whether the website in the webview is inspectable or not, ios only | <code>false</code> | |
|
|
314
|
+
| **`isAnimated`** | <code>boolean</code> | Whether the webview opening is animated or not, ios only | <code>true</code> | |
|
|
296
315
|
| **`showReloadButton`** | <code>boolean</code> | Shows a reload button that reloads the web page | <code>false</code> | 1.0.15 |
|
|
297
316
|
| **`closeModal`** | <code>boolean</code> | CloseModal: if true a confirm will be displayed when user clicks on close button, if false the browser will be closed immediately. | <code>false</code> | 1.1.0 |
|
|
298
317
|
| **`closeModalTitle`** | <code>string</code> | CloseModalTitle: title of the confirm when user clicks on close button, only on IOS | <code>'Close'</code> | 1.1.0 |
|
|
@@ -188,6 +188,7 @@ public class InAppBrowserPlugin
|
|
|
188
188
|
@PluginMethod
|
|
189
189
|
public void clearCookies(PluginCall call) {
|
|
190
190
|
String url = call.getString("url");
|
|
191
|
+
Boolean clearCache = call.getBoolean("cache", false);
|
|
191
192
|
if (url == null || TextUtils.isEmpty(url)) {
|
|
192
193
|
call.reject("Invalid URL");
|
|
193
194
|
} else {
|
|
@@ -201,6 +202,9 @@ public class InAppBrowserPlugin
|
|
|
201
202
|
url,
|
|
202
203
|
cookieName + "=; Expires=Thu, 01 Jan 1970 00:00:01 GMT"
|
|
203
204
|
);
|
|
205
|
+
if (clearCache) {
|
|
206
|
+
cookieManager.removeSessionCookie();
|
|
207
|
+
}
|
|
204
208
|
}
|
|
205
209
|
}
|
|
206
210
|
call.resolve();
|
|
@@ -310,6 +314,28 @@ public class InAppBrowserPlugin
|
|
|
310
314
|
);
|
|
311
315
|
}
|
|
312
316
|
|
|
317
|
+
@PluginMethod
|
|
318
|
+
public void executeScript(PluginCall call) {
|
|
319
|
+
String script = call.getString("code");
|
|
320
|
+
if (script == null || TextUtils.isEmpty(script)) {
|
|
321
|
+
call.reject("No script to run");
|
|
322
|
+
}
|
|
323
|
+
|
|
324
|
+
if (webViewDialog != null) {
|
|
325
|
+
this.getActivity()
|
|
326
|
+
.runOnUiThread(
|
|
327
|
+
new Runnable() {
|
|
328
|
+
@Override
|
|
329
|
+
public void run() {
|
|
330
|
+
webViewDialog.executeScript(script);
|
|
331
|
+
}
|
|
332
|
+
}
|
|
333
|
+
);
|
|
334
|
+
}
|
|
335
|
+
|
|
336
|
+
call.resolve();
|
|
337
|
+
}
|
|
338
|
+
|
|
313
339
|
@PluginMethod
|
|
314
340
|
public void reload(PluginCall call) {
|
|
315
341
|
if (webViewDialog != null) {
|
|
@@ -339,6 +365,7 @@ public class InAppBrowserPlugin
|
|
|
339
365
|
new JSObject().put("url", webViewDialog.getUrl())
|
|
340
366
|
);
|
|
341
367
|
webViewDialog.dismiss();
|
|
368
|
+
webViewDialog.destroy();
|
|
342
369
|
webViewDialog = null;
|
|
343
370
|
}
|
|
344
371
|
}
|
|
@@ -167,10 +167,18 @@ public class WebViewDialog extends Dialog {
|
|
|
167
167
|
_webView.reload();
|
|
168
168
|
}
|
|
169
169
|
|
|
170
|
+
public void destroy() {
|
|
171
|
+
_webView.destroy();
|
|
172
|
+
}
|
|
173
|
+
|
|
170
174
|
public String getUrl() {
|
|
171
175
|
return _webView.getUrl();
|
|
172
176
|
}
|
|
173
177
|
|
|
178
|
+
public void executeScript(String script) {
|
|
179
|
+
_webView.evaluateJavascript(script, null);
|
|
180
|
+
}
|
|
181
|
+
|
|
174
182
|
public void setUrl(String url) {
|
|
175
183
|
Map<String, String> requestHeaders = new HashMap<>();
|
|
176
184
|
if (_options.getHeaders() != null) {
|
|
@@ -264,6 +272,7 @@ public class WebViewDialog extends Dialog {
|
|
|
264
272
|
// Close button clicked, do something
|
|
265
273
|
dismiss();
|
|
266
274
|
_options.getCallbacks().closeEvent(_webView.getUrl());
|
|
275
|
+
_webView.destroy();
|
|
267
276
|
}
|
|
268
277
|
}
|
|
269
278
|
)
|
|
@@ -272,6 +281,7 @@ public class WebViewDialog extends Dialog {
|
|
|
272
281
|
} else {
|
|
273
282
|
dismiss();
|
|
274
283
|
_options.getCallbacks().closeEvent(_webView.getUrl());
|
|
284
|
+
_webView.destroy();
|
|
275
285
|
}
|
|
276
286
|
}
|
|
277
287
|
}
|
package/dist/docs.json
CHANGED
|
@@ -112,6 +112,22 @@
|
|
|
112
112
|
],
|
|
113
113
|
"slug": "openwebview"
|
|
114
114
|
},
|
|
115
|
+
{
|
|
116
|
+
"name": "executeScript",
|
|
117
|
+
"signature": "({ code }: { code: string; }) => Promise<void>",
|
|
118
|
+
"parameters": [
|
|
119
|
+
{
|
|
120
|
+
"name": "__0",
|
|
121
|
+
"docs": "",
|
|
122
|
+
"type": "{ code: string; }"
|
|
123
|
+
}
|
|
124
|
+
],
|
|
125
|
+
"returns": "Promise<void>",
|
|
126
|
+
"tags": [],
|
|
127
|
+
"docs": "Injects JavaScript code into the InAppBrowser window.",
|
|
128
|
+
"complexTypes": [],
|
|
129
|
+
"slug": "executescript"
|
|
130
|
+
},
|
|
115
131
|
{
|
|
116
132
|
"name": "setUrl",
|
|
117
133
|
"signature": "(options: { url: string; }) => Promise<any>",
|
|
@@ -324,6 +340,13 @@
|
|
|
324
340
|
"docs": "",
|
|
325
341
|
"complexTypes": [],
|
|
326
342
|
"type": "string"
|
|
343
|
+
},
|
|
344
|
+
{
|
|
345
|
+
"name": "cache",
|
|
346
|
+
"tags": [],
|
|
347
|
+
"docs": "",
|
|
348
|
+
"complexTypes": [],
|
|
349
|
+
"type": "boolean | undefined"
|
|
327
350
|
}
|
|
328
351
|
]
|
|
329
352
|
},
|
|
@@ -471,7 +494,7 @@
|
|
|
471
494
|
],
|
|
472
495
|
"docs": "Title of the browser",
|
|
473
496
|
"complexTypes": [],
|
|
474
|
-
"type": "string"
|
|
497
|
+
"type": "string | undefined"
|
|
475
498
|
},
|
|
476
499
|
{
|
|
477
500
|
"name": "backgroundColor",
|
|
@@ -507,6 +530,30 @@
|
|
|
507
530
|
"complexTypes": [],
|
|
508
531
|
"type": "boolean | undefined"
|
|
509
532
|
},
|
|
533
|
+
{
|
|
534
|
+
"name": "isInspectable",
|
|
535
|
+
"tags": [
|
|
536
|
+
{
|
|
537
|
+
"text": "false",
|
|
538
|
+
"name": "default"
|
|
539
|
+
}
|
|
540
|
+
],
|
|
541
|
+
"docs": "Whether the website in the webview is inspectable or not, ios only",
|
|
542
|
+
"complexTypes": [],
|
|
543
|
+
"type": "boolean | undefined"
|
|
544
|
+
},
|
|
545
|
+
{
|
|
546
|
+
"name": "isAnimated",
|
|
547
|
+
"tags": [
|
|
548
|
+
{
|
|
549
|
+
"text": "true",
|
|
550
|
+
"name": "default"
|
|
551
|
+
}
|
|
552
|
+
],
|
|
553
|
+
"docs": "Whether the webview opening is animated or not, ios only",
|
|
554
|
+
"complexTypes": [],
|
|
555
|
+
"type": "boolean | undefined"
|
|
556
|
+
},
|
|
510
557
|
{
|
|
511
558
|
"name": "showReloadButton",
|
|
512
559
|
"tags": [
|
|
@@ -36,6 +36,7 @@ export interface GetCookieOptions {
|
|
|
36
36
|
}
|
|
37
37
|
export interface ClearCookieOptions {
|
|
38
38
|
url: string;
|
|
39
|
+
cache?: boolean;
|
|
39
40
|
}
|
|
40
41
|
export interface OpenOptions {
|
|
41
42
|
/**
|
|
@@ -93,7 +94,7 @@ export interface OpenWebViewOptions {
|
|
|
93
94
|
* @since 0.1.0
|
|
94
95
|
* @default 'New Window'
|
|
95
96
|
*/
|
|
96
|
-
title
|
|
97
|
+
title?: string;
|
|
97
98
|
/**
|
|
98
99
|
* Background color of the browser, only on IOS
|
|
99
100
|
* @since 0.1.0
|
|
@@ -108,6 +109,18 @@ export interface OpenWebViewOptions {
|
|
|
108
109
|
* @default false
|
|
109
110
|
*/
|
|
110
111
|
isPresentAfterPageLoad?: boolean;
|
|
112
|
+
/**
|
|
113
|
+
* Whether the website in the webview is inspectable or not, ios only
|
|
114
|
+
*
|
|
115
|
+
* @default false
|
|
116
|
+
*/
|
|
117
|
+
isInspectable?: boolean;
|
|
118
|
+
/**
|
|
119
|
+
* Whether the webview opening is animated or not, ios only
|
|
120
|
+
*
|
|
121
|
+
* @default true
|
|
122
|
+
*/
|
|
123
|
+
isAnimated?: boolean;
|
|
111
124
|
/**
|
|
112
125
|
* Shows a reload button that reloads the web page
|
|
113
126
|
* @since 1.0.15
|
|
@@ -197,6 +210,12 @@ export interface InAppBrowserPlugin {
|
|
|
197
210
|
* @since 0.1.0
|
|
198
211
|
*/
|
|
199
212
|
openWebView(options: OpenWebViewOptions): Promise<any>;
|
|
213
|
+
/**
|
|
214
|
+
* Injects JavaScript code into the InAppBrowser window.
|
|
215
|
+
*/
|
|
216
|
+
executeScript({ code }: {
|
|
217
|
+
code: string;
|
|
218
|
+
}): Promise<void>;
|
|
200
219
|
setUrl(options: {
|
|
201
220
|
url: string;
|
|
202
221
|
}): Promise<any>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"definitions.js","sourceRoot":"","sources":["../../src/definitions.ts"],"names":[],"mappings":"AAsBA,MAAM,CAAN,IAAY,eAGX;AAHD,WAAY,eAAe;IACzB,kCAAe,CAAA;IACf,kCAAe,CAAA;AACjB,CAAC,EAHW,eAAe,KAAf,eAAe,QAG1B;AACD,MAAM,CAAN,IAAY,WAKX;AALD,WAAY,WAAW;IACrB,oCAAqB,CAAA;IACrB,wCAAyB,CAAA;IACzB,8BAAe,CAAA;IACf,2BAAY,CAAA;AACd,CAAC,EALW,WAAW,KAAX,WAAW,QAKtB","sourcesContent":["import type { PluginListenerHandle } from \"@capacitor/core\";\n\nexport interface UrlEvent {\n /**\n * Emit when the url changes\n *\n * @since 0.0.1\n */\n url: string;\n}\nexport interface BtnEvent {\n /**\n * Emit when a button is clicked.\n *\n * @since 0.0.1\n */\n url: string;\n}\n\nexport type UrlChangeListener = (state: UrlEvent) => void;\nexport type ConfirmBtnListener = (state: BtnEvent) => void;\n\nexport enum BackgroundColor {\n WHITE = \"white\",\n BLACK = \"black\",\n}\nexport enum ToolBarType {\n ACTIVITY = \"activity\",\n NAVIGATION = \"navigation\",\n BLANK = \"blank\",\n DEFAULT = \"\",\n}\n\nexport interface Headers {\n [key: string]: string;\n}\n\nexport interface GetCookieOptions {\n url: string;\n includeHttpOnly?: boolean;\n}\n\nexport interface ClearCookieOptions {\n url: string;\n}\n\nexport interface OpenOptions {\n /**\n * Target URL to load.\n * @since 0.1.0\n */\n url: string;\n /**\n * Headers to send with the request.\n * @since 0.1.0\n */\n headers?: Headers;\n /**\n * if true, the browser will be presented after the page is loaded, if false, the browser will be presented immediately.\n * @since 0.1.0\n */\n isPresentAfterPageLoad?: boolean;\n preventDeeplink?: boolean;\n}\n\nexport interface DisclaimerOptions {\n title: string;\n message: string;\n confirmBtn: string;\n cancelBtn: string;\n}\n\nexport interface OpenWebViewOptions {\n /**\n * Target URL to load.\n * @since 0.1.0\n */\n url: string;\n /**\n * Headers to send with the request.\n * @since 0.1.0\n */\n headers?: Headers;\n /**\n * share options\n * @since 0.1.0\n */\n shareDisclaimer?: DisclaimerOptions;\n /**\n * Toolbar type\n * @since 0.1.0\n * @default ToolBarType.DEFAULT\n */\n toolbarType?: ToolBarType;\n /**\n * Share subject\n * @since 0.1.0\n */\n shareSubject?: string;\n /**\n * Title of the browser\n * @since 0.1.0\n * @default 'New Window'\n */\n title
|
|
1
|
+
{"version":3,"file":"definitions.js","sourceRoot":"","sources":["../../src/definitions.ts"],"names":[],"mappings":"AAsBA,MAAM,CAAN,IAAY,eAGX;AAHD,WAAY,eAAe;IACzB,kCAAe,CAAA;IACf,kCAAe,CAAA;AACjB,CAAC,EAHW,eAAe,KAAf,eAAe,QAG1B;AACD,MAAM,CAAN,IAAY,WAKX;AALD,WAAY,WAAW;IACrB,oCAAqB,CAAA;IACrB,wCAAyB,CAAA;IACzB,8BAAe,CAAA;IACf,2BAAY,CAAA;AACd,CAAC,EALW,WAAW,KAAX,WAAW,QAKtB","sourcesContent":["import type { PluginListenerHandle } from \"@capacitor/core\";\n\nexport interface UrlEvent {\n /**\n * Emit when the url changes\n *\n * @since 0.0.1\n */\n url: string;\n}\nexport interface BtnEvent {\n /**\n * Emit when a button is clicked.\n *\n * @since 0.0.1\n */\n url: string;\n}\n\nexport type UrlChangeListener = (state: UrlEvent) => void;\nexport type ConfirmBtnListener = (state: BtnEvent) => void;\n\nexport enum BackgroundColor {\n WHITE = \"white\",\n BLACK = \"black\",\n}\nexport enum ToolBarType {\n ACTIVITY = \"activity\",\n NAVIGATION = \"navigation\",\n BLANK = \"blank\",\n DEFAULT = \"\",\n}\n\nexport interface Headers {\n [key: string]: string;\n}\n\nexport interface GetCookieOptions {\n url: string;\n includeHttpOnly?: boolean;\n}\n\nexport interface ClearCookieOptions {\n url: string;\n cache?: boolean;\n}\n\nexport interface OpenOptions {\n /**\n * Target URL to load.\n * @since 0.1.0\n */\n url: string;\n /**\n * Headers to send with the request.\n * @since 0.1.0\n */\n headers?: Headers;\n /**\n * if true, the browser will be presented after the page is loaded, if false, the browser will be presented immediately.\n * @since 0.1.0\n */\n isPresentAfterPageLoad?: boolean;\n preventDeeplink?: boolean;\n}\n\nexport interface DisclaimerOptions {\n title: string;\n message: string;\n confirmBtn: string;\n cancelBtn: string;\n}\n\nexport interface OpenWebViewOptions {\n /**\n * Target URL to load.\n * @since 0.1.0\n */\n url: string;\n /**\n * Headers to send with the request.\n * @since 0.1.0\n */\n headers?: Headers;\n /**\n * share options\n * @since 0.1.0\n */\n shareDisclaimer?: DisclaimerOptions;\n /**\n * Toolbar type\n * @since 0.1.0\n * @default ToolBarType.DEFAULT\n */\n toolbarType?: ToolBarType;\n /**\n * Share subject\n * @since 0.1.0\n */\n shareSubject?: string;\n /**\n * Title of the browser\n * @since 0.1.0\n * @default 'New Window'\n */\n title?: string;\n /**\n * Background color of the browser, only on IOS\n * @since 0.1.0\n * @default BackgroundColor.BLACK\n */\n backgroundColor?: BackgroundColor;\n /**\n * Open url in a new window fullscreen\n *\n * isPresentAfterPageLoad: if true, the browser will be presented after the page is loaded, if false, the browser will be presented immediately.\n * @since 0.1.0\n * @default false\n */\n isPresentAfterPageLoad?: boolean;\n /**\n * Whether the website in the webview is inspectable or not, ios only\n *\n * @default false\n */\n isInspectable?: boolean;\n /**\n * Whether the webview opening is animated or not, ios only\n *\n * @default true\n */\n isAnimated?: boolean;\n /**\n * Shows a reload button that reloads the web page\n * @since 1.0.15\n * @default false\n */\n showReloadButton?: boolean;\n /**\n * CloseModal: if true a confirm will be displayed when user clicks on close button, if false the browser will be closed immediately.\n *\n * @since 1.1.0\n * @default false\n */\n closeModal?: boolean;\n /**\n * CloseModalTitle: title of the confirm when user clicks on close button, only on IOS\n *\n * @since 1.1.0\n * @default 'Close'\n */\n closeModalTitle?: string;\n /**\n * CloseModalDescription: description of the confirm when user clicks on close button, only on IOS\n *\n * @since 1.1.0\n * @default 'Are you sure you want to close this window?'\n */\n closeModalDescription?: string;\n /**\n * CloseModalOk: text of the confirm button when user clicks on close button, only on IOS\n *\n * @since 1.1.0\n * @default 'Close'\n */\n closeModalOk?: string;\n /**\n * CloseModalCancel: text of the cancel button when user clicks on close button, only on IOS\n *\n * @since 1.1.0\n * @default 'Cancel'\n */\n closeModalCancel?: string;\n /**\n * visibleTitle: if true the website title would be shown else shown empty\n *\n * @since 1.2.5\n * @default true\n */\n visibleTitle?: boolean;\n /**\n * toolbarColor: color of the toolbar in hex format\n *\n * @since 1.2.5\n * @default '#ffffff''\n */\n toolbarColor?: string;\n /**\n * showArrow: if true an arrow would be shown instead of cross for closing the window\n *\n * @since 1.2.5\n * @default false\n */\n showArrow?: boolean;\n}\n\nexport interface InAppBrowserPlugin {\n /**\n * Open url in a new window fullscreen\n *\n * @since 0.1.0\n */\n open(options: OpenOptions): Promise<any>;\n\n /**\n * Clear cookies of url\n *\n * @since 0.5.0\n */\n clearCookies(options: ClearCookieOptions): Promise<any>;\n\n /**\n * Get cookies for a specific URL.\n * @param options The options, including the URL to get cookies for.\n * @returns A promise that resolves with the cookies.\n */\n getCookies(options: GetCookieOptions): Promise<Record<string, string>>;\n\n close(): Promise<any>;\n /**\n * Open url in a new webview with toolbars\n *\n * @since 0.1.0\n */\n openWebView(options: OpenWebViewOptions): Promise<any>;\n /**\n * Injects JavaScript code into the InAppBrowser window.\n */\n executeScript({ code }: { code: string }): Promise<void>;\n setUrl(options: { url: string }): Promise<any>;\n /**\n * Listen for url change, only for openWebView\n *\n * @since 0.0.1\n */\n addListener(\n eventName: \"urlChangeEvent\",\n listenerFunc: UrlChangeListener\n ): Promise<PluginListenerHandle> & PluginListenerHandle;\n\n /**\n * Listen for close click only for openWebView\n *\n * @since 0.4.0\n */\n addListener(\n eventName: \"closeEvent\",\n listenerFunc: UrlChangeListener\n ): Promise<PluginListenerHandle> & PluginListenerHandle;\n /**\n * Will be triggered when user clicks on confirm button when disclaimer is required, works only on iOS\n *\n * @since 0.0.1\n */\n addListener(\n eventName: \"confirmBtnClicked\",\n listenerFunc: ConfirmBtnListener\n ): Promise<PluginListenerHandle> & PluginListenerHandle;\n\n /**\n * Remove all listeners for this plugin.\n *\n * @since 1.0.0\n */\n removeAllListeners(): Promise<void>;\n\n /**\n * Reload the current web page.\n *\n * @since 1.0.0\n */\n reload(): Promise<any>; // Add this line\n}\n"]}
|
package/dist/esm/web.d.ts
CHANGED
|
@@ -5,6 +5,9 @@ export declare class InAppBrowserWeb extends WebPlugin implements InAppBrowserPl
|
|
|
5
5
|
clearCookies(options: ClearCookieOptions): Promise<any>;
|
|
6
6
|
getCookies(options: GetCookieOptions): Promise<any>;
|
|
7
7
|
openWebView(options: OpenWebViewOptions): Promise<any>;
|
|
8
|
+
executeScript({ code }: {
|
|
9
|
+
code: string;
|
|
10
|
+
}): Promise<any>;
|
|
8
11
|
close(): Promise<any>;
|
|
9
12
|
setUrl(options: {
|
|
10
13
|
url: string;
|
package/dist/esm/web.js
CHANGED
package/dist/esm/web.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"web.js","sourceRoot":"","sources":["../../src/web.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAU5C,MAAM,OAAO,eAAgB,SAAQ,SAAS;IAC5C,KAAK,CAAC,IAAI,CAAC,OAAoB;QAC7B,OAAO,CAAC,GAAG,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;QAC7B,OAAO,OAAO,CAAC;IACjB,CAAC;IAED,KAAK,CAAC,YAAY,CAAC,OAA2B;QAC5C,OAAO,CAAC,GAAG,CAAC,cAAc,EAAE,OAAO,CAAC,CAAC;QACrC,OAAO;IACT,CAAC;IAED,KAAK,CAAC,UAAU,CAAC,OAAyB;QACxC,oCAAoC;QACpC,OAAO,OAAO,CAAC;IACjB,CAAC;IAED,KAAK,CAAC,WAAW,CAAC,OAA2B;QAC3C,OAAO,CAAC,GAAG,CAAC,aAAa,EAAE,OAAO,CAAC,CAAC;QACpC,OAAO,OAAO,CAAC;IACjB,CAAC;IAED,KAAK,CAAC,KAAK;QACT,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;QACrB,OAAO;IACT,CAAC;IAED,KAAK,CAAC,MAAM,CAAC,OAAwB;QACnC,OAAO,CAAC,GAAG,CAAC,QAAQ,EAAE,OAAO,CAAC,GAAG,CAAC,CAAC;QACnC,OAAO;IACT,CAAC;IAED,KAAK,CAAC,MAAM;QACV,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QACtB,OAAO;IACT,CAAC;CACF","sourcesContent":["import { WebPlugin } from \"@capacitor/core\";\n\nimport type {\n InAppBrowserPlugin,\n OpenWebViewOptions,\n OpenOptions,\n GetCookieOptions,\n ClearCookieOptions,\n} from \"./definitions\";\n\nexport class InAppBrowserWeb extends WebPlugin implements InAppBrowserPlugin {\n async open(options: OpenOptions): Promise<any> {\n console.log(\"open\", options);\n return options;\n }\n\n async clearCookies(options: ClearCookieOptions): Promise<any> {\n console.log(\"cleanCookies\", options);\n return;\n }\n\n async getCookies(options: GetCookieOptions): Promise<any> {\n // Web implementation to get cookies\n return options;\n }\n\n async openWebView(options: OpenWebViewOptions): Promise<any> {\n console.log(\"openWebView\", options);\n return options;\n }\n\n async close(): Promise<any> {\n console.log(\"close\");\n return;\n }\n\n async setUrl(options: { url: string }): Promise<any> {\n console.log(\"setUrl\", options.url);\n return;\n }\n\n async reload(): Promise<any> {\n console.log(\"reload\");\n return;\n }\n}\n"]}
|
|
1
|
+
{"version":3,"file":"web.js","sourceRoot":"","sources":["../../src/web.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAU5C,MAAM,OAAO,eAAgB,SAAQ,SAAS;IAC5C,KAAK,CAAC,IAAI,CAAC,OAAoB;QAC7B,OAAO,CAAC,GAAG,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;QAC7B,OAAO,OAAO,CAAC;IACjB,CAAC;IAED,KAAK,CAAC,YAAY,CAAC,OAA2B;QAC5C,OAAO,CAAC,GAAG,CAAC,cAAc,EAAE,OAAO,CAAC,CAAC;QACrC,OAAO;IACT,CAAC;IAED,KAAK,CAAC,UAAU,CAAC,OAAyB;QACxC,oCAAoC;QACpC,OAAO,OAAO,CAAC;IACjB,CAAC;IAED,KAAK,CAAC,WAAW,CAAC,OAA2B;QAC3C,OAAO,CAAC,GAAG,CAAC,aAAa,EAAE,OAAO,CAAC,CAAC;QACpC,OAAO,OAAO,CAAC;IACjB,CAAC;IAED,KAAK,CAAC,aAAa,CAAC,EAAE,IAAI,EAAoB;QAC5C,OAAO,CAAC,GAAG,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;QAC1B,OAAO,IAAI,CAAC;IACd,CAAC;IAED,KAAK,CAAC,KAAK;QACT,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;QACrB,OAAO;IACT,CAAC;IAED,KAAK,CAAC,MAAM,CAAC,OAAwB;QACnC,OAAO,CAAC,GAAG,CAAC,QAAQ,EAAE,OAAO,CAAC,GAAG,CAAC,CAAC;QACnC,OAAO;IACT,CAAC;IAED,KAAK,CAAC,MAAM;QACV,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QACtB,OAAO;IACT,CAAC;CACF","sourcesContent":["import { WebPlugin } from \"@capacitor/core\";\n\nimport type {\n InAppBrowserPlugin,\n OpenWebViewOptions,\n OpenOptions,\n GetCookieOptions,\n ClearCookieOptions,\n} from \"./definitions\";\n\nexport class InAppBrowserWeb extends WebPlugin implements InAppBrowserPlugin {\n async open(options: OpenOptions): Promise<any> {\n console.log(\"open\", options);\n return options;\n }\n\n async clearCookies(options: ClearCookieOptions): Promise<any> {\n console.log(\"cleanCookies\", options);\n return;\n }\n\n async getCookies(options: GetCookieOptions): Promise<any> {\n // Web implementation to get cookies\n return options;\n }\n\n async openWebView(options: OpenWebViewOptions): Promise<any> {\n console.log(\"openWebView\", options);\n return options;\n }\n\n async executeScript({ code }: { code: string }): Promise<any> {\n console.log(\"code\", code);\n return code;\n }\n\n async close(): Promise<any> {\n console.log(\"close\");\n return;\n }\n\n async setUrl(options: { url: string }): Promise<any> {\n console.log(\"setUrl\", options.url);\n return;\n }\n\n async reload(): Promise<any> {\n console.log(\"reload\");\n return;\n }\n}\n"]}
|
package/dist/plugin.cjs.js
CHANGED
package/dist/plugin.cjs.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"plugin.cjs.js","sources":["esm/definitions.js","esm/index.js","esm/web.js"],"sourcesContent":["export var BackgroundColor;\n(function (BackgroundColor) {\n BackgroundColor[\"WHITE\"] = \"white\";\n BackgroundColor[\"BLACK\"] = \"black\";\n})(BackgroundColor || (BackgroundColor = {}));\nexport var ToolBarType;\n(function (ToolBarType) {\n ToolBarType[\"ACTIVITY\"] = \"activity\";\n ToolBarType[\"NAVIGATION\"] = \"navigation\";\n ToolBarType[\"BLANK\"] = \"blank\";\n ToolBarType[\"DEFAULT\"] = \"\";\n})(ToolBarType || (ToolBarType = {}));\n//# sourceMappingURL=definitions.js.map","import { registerPlugin } from \"@capacitor/core\";\nconst InAppBrowser = registerPlugin(\"InAppBrowser\", {\n web: () => import(\"./web\").then((m) => new m.InAppBrowserWeb()),\n});\nexport * from \"./definitions\";\nexport { InAppBrowser };\n//# sourceMappingURL=index.js.map","import { WebPlugin } from \"@capacitor/core\";\nexport class InAppBrowserWeb extends WebPlugin {\n async open(options) {\n console.log(\"open\", options);\n return options;\n }\n async clearCookies(options) {\n console.log(\"cleanCookies\", options);\n return;\n }\n async getCookies(options) {\n // Web implementation to get cookies\n return options;\n }\n async openWebView(options) {\n console.log(\"openWebView\", options);\n return options;\n }\n async close() {\n console.log(\"close\");\n return;\n }\n async setUrl(options) {\n console.log(\"setUrl\", options.url);\n return;\n }\n async reload() {\n console.log(\"reload\");\n return;\n }\n}\n//# sourceMappingURL=web.js.map"],"names":["BackgroundColor","ToolBarType","registerPlugin","WebPlugin"],"mappings":";;;;AAAWA,iCAAgB;AAC3B,CAAC,UAAU,eAAe,EAAE;AAC5B,IAAI,eAAe,CAAC,OAAO,CAAC,GAAG,OAAO,CAAC;AACvC,IAAI,eAAe,CAAC,OAAO,CAAC,GAAG,OAAO,CAAC;AACvC,CAAC,EAAEA,uBAAe,KAAKA,uBAAe,GAAG,EAAE,CAAC,CAAC,CAAC;AACnCC,6BAAY;AACvB,CAAC,UAAU,WAAW,EAAE;AACxB,IAAI,WAAW,CAAC,UAAU,CAAC,GAAG,UAAU,CAAC;AACzC,IAAI,WAAW,CAAC,YAAY,CAAC,GAAG,YAAY,CAAC;AAC7C,IAAI,WAAW,CAAC,OAAO,CAAC,GAAG,OAAO,CAAC;AACnC,IAAI,WAAW,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC;AAChC,CAAC,EAAEA,mBAAW,KAAKA,mBAAW,GAAG,EAAE,CAAC,CAAC;;ACVhC,MAAC,YAAY,GAAGC,mBAAc,CAAC,cAAc,EAAE;AACpD,IAAI,GAAG,EAAE,MAAM,mDAAe,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,IAAI,CAAC,CAAC,eAAe,EAAE,CAAC;AACnE,CAAC;;ACFM,MAAM,eAAe,SAASC,cAAS,CAAC;AAC/C,IAAI,MAAM,IAAI,CAAC,OAAO,EAAE;AACxB,QAAQ,OAAO,CAAC,GAAG,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;AACrC,QAAQ,OAAO,OAAO,CAAC;AACvB,KAAK;AACL,IAAI,MAAM,YAAY,CAAC,OAAO,EAAE;AAChC,QAAQ,OAAO,CAAC,GAAG,CAAC,cAAc,EAAE,OAAO,CAAC,CAAC;AAC7C,QAAQ,OAAO;AACf,KAAK;AACL,IAAI,MAAM,UAAU,CAAC,OAAO,EAAE;AAC9B;AACA,QAAQ,OAAO,OAAO,CAAC;AACvB,KAAK;AACL,IAAI,MAAM,WAAW,CAAC,OAAO,EAAE;AAC/B,QAAQ,OAAO,CAAC,GAAG,CAAC,aAAa,EAAE,OAAO,CAAC,CAAC;AAC5C,QAAQ,OAAO,OAAO,CAAC;AACvB,KAAK;AACL,IAAI,MAAM,KAAK,GAAG;AAClB,QAAQ,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;AAC7B,QAAQ,OAAO;AACf,KAAK;AACL,IAAI,MAAM,MAAM,CAAC,OAAO,EAAE;AAC1B,QAAQ,OAAO,CAAC,GAAG,CAAC,QAAQ,EAAE,OAAO,CAAC,GAAG,CAAC,CAAC;AAC3C,QAAQ,OAAO;AACf,KAAK;AACL,IAAI,MAAM,MAAM,GAAG;AACnB,QAAQ,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;AAC9B,QAAQ,OAAO;AACf,KAAK;AACL;;;;;;;;;"}
|
|
1
|
+
{"version":3,"file":"plugin.cjs.js","sources":["esm/definitions.js","esm/index.js","esm/web.js"],"sourcesContent":["export var BackgroundColor;\n(function (BackgroundColor) {\n BackgroundColor[\"WHITE\"] = \"white\";\n BackgroundColor[\"BLACK\"] = \"black\";\n})(BackgroundColor || (BackgroundColor = {}));\nexport var ToolBarType;\n(function (ToolBarType) {\n ToolBarType[\"ACTIVITY\"] = \"activity\";\n ToolBarType[\"NAVIGATION\"] = \"navigation\";\n ToolBarType[\"BLANK\"] = \"blank\";\n ToolBarType[\"DEFAULT\"] = \"\";\n})(ToolBarType || (ToolBarType = {}));\n//# sourceMappingURL=definitions.js.map","import { registerPlugin } from \"@capacitor/core\";\nconst InAppBrowser = registerPlugin(\"InAppBrowser\", {\n web: () => import(\"./web\").then((m) => new m.InAppBrowserWeb()),\n});\nexport * from \"./definitions\";\nexport { InAppBrowser };\n//# sourceMappingURL=index.js.map","import { WebPlugin } from \"@capacitor/core\";\nexport class InAppBrowserWeb extends WebPlugin {\n async open(options) {\n console.log(\"open\", options);\n return options;\n }\n async clearCookies(options) {\n console.log(\"cleanCookies\", options);\n return;\n }\n async getCookies(options) {\n // Web implementation to get cookies\n return options;\n }\n async openWebView(options) {\n console.log(\"openWebView\", options);\n return options;\n }\n async executeScript({ code }) {\n console.log(\"code\", code);\n return code;\n }\n async close() {\n console.log(\"close\");\n return;\n }\n async setUrl(options) {\n console.log(\"setUrl\", options.url);\n return;\n }\n async reload() {\n console.log(\"reload\");\n return;\n }\n}\n//# sourceMappingURL=web.js.map"],"names":["BackgroundColor","ToolBarType","registerPlugin","WebPlugin"],"mappings":";;;;AAAWA,iCAAgB;AAC3B,CAAC,UAAU,eAAe,EAAE;AAC5B,IAAI,eAAe,CAAC,OAAO,CAAC,GAAG,OAAO,CAAC;AACvC,IAAI,eAAe,CAAC,OAAO,CAAC,GAAG,OAAO,CAAC;AACvC,CAAC,EAAEA,uBAAe,KAAKA,uBAAe,GAAG,EAAE,CAAC,CAAC,CAAC;AACnCC,6BAAY;AACvB,CAAC,UAAU,WAAW,EAAE;AACxB,IAAI,WAAW,CAAC,UAAU,CAAC,GAAG,UAAU,CAAC;AACzC,IAAI,WAAW,CAAC,YAAY,CAAC,GAAG,YAAY,CAAC;AAC7C,IAAI,WAAW,CAAC,OAAO,CAAC,GAAG,OAAO,CAAC;AACnC,IAAI,WAAW,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC;AAChC,CAAC,EAAEA,mBAAW,KAAKA,mBAAW,GAAG,EAAE,CAAC,CAAC;;ACVhC,MAAC,YAAY,GAAGC,mBAAc,CAAC,cAAc,EAAE;AACpD,IAAI,GAAG,EAAE,MAAM,mDAAe,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,IAAI,CAAC,CAAC,eAAe,EAAE,CAAC;AACnE,CAAC;;ACFM,MAAM,eAAe,SAASC,cAAS,CAAC;AAC/C,IAAI,MAAM,IAAI,CAAC,OAAO,EAAE;AACxB,QAAQ,OAAO,CAAC,GAAG,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;AACrC,QAAQ,OAAO,OAAO,CAAC;AACvB,KAAK;AACL,IAAI,MAAM,YAAY,CAAC,OAAO,EAAE;AAChC,QAAQ,OAAO,CAAC,GAAG,CAAC,cAAc,EAAE,OAAO,CAAC,CAAC;AAC7C,QAAQ,OAAO;AACf,KAAK;AACL,IAAI,MAAM,UAAU,CAAC,OAAO,EAAE;AAC9B;AACA,QAAQ,OAAO,OAAO,CAAC;AACvB,KAAK;AACL,IAAI,MAAM,WAAW,CAAC,OAAO,EAAE;AAC/B,QAAQ,OAAO,CAAC,GAAG,CAAC,aAAa,EAAE,OAAO,CAAC,CAAC;AAC5C,QAAQ,OAAO,OAAO,CAAC;AACvB,KAAK;AACL,IAAI,MAAM,aAAa,CAAC,EAAE,IAAI,EAAE,EAAE;AAClC,QAAQ,OAAO,CAAC,GAAG,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;AAClC,QAAQ,OAAO,IAAI,CAAC;AACpB,KAAK;AACL,IAAI,MAAM,KAAK,GAAG;AAClB,QAAQ,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;AAC7B,QAAQ,OAAO;AACf,KAAK;AACL,IAAI,MAAM,MAAM,CAAC,OAAO,EAAE;AAC1B,QAAQ,OAAO,CAAC,GAAG,CAAC,QAAQ,EAAE,OAAO,CAAC,GAAG,CAAC,CAAC;AAC3C,QAAQ,OAAO;AACf,KAAK;AACL,IAAI,MAAM,MAAM,GAAG;AACnB,QAAQ,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;AAC9B,QAAQ,OAAO;AACf,KAAK;AACL;;;;;;;;;"}
|
package/dist/plugin.js
CHANGED
|
@@ -35,6 +35,10 @@ var capacitorInAppBrowser = (function (exports, core) {
|
|
|
35
35
|
console.log("openWebView", options);
|
|
36
36
|
return options;
|
|
37
37
|
}
|
|
38
|
+
async executeScript({ code }) {
|
|
39
|
+
console.log("code", code);
|
|
40
|
+
return code;
|
|
41
|
+
}
|
|
38
42
|
async close() {
|
|
39
43
|
console.log("close");
|
|
40
44
|
return;
|
package/dist/plugin.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"plugin.js","sources":["esm/definitions.js","esm/index.js","esm/web.js"],"sourcesContent":["export var BackgroundColor;\n(function (BackgroundColor) {\n BackgroundColor[\"WHITE\"] = \"white\";\n BackgroundColor[\"BLACK\"] = \"black\";\n})(BackgroundColor || (BackgroundColor = {}));\nexport var ToolBarType;\n(function (ToolBarType) {\n ToolBarType[\"ACTIVITY\"] = \"activity\";\n ToolBarType[\"NAVIGATION\"] = \"navigation\";\n ToolBarType[\"BLANK\"] = \"blank\";\n ToolBarType[\"DEFAULT\"] = \"\";\n})(ToolBarType || (ToolBarType = {}));\n//# sourceMappingURL=definitions.js.map","import { registerPlugin } from \"@capacitor/core\";\nconst InAppBrowser = registerPlugin(\"InAppBrowser\", {\n web: () => import(\"./web\").then((m) => new m.InAppBrowserWeb()),\n});\nexport * from \"./definitions\";\nexport { InAppBrowser };\n//# sourceMappingURL=index.js.map","import { WebPlugin } from \"@capacitor/core\";\nexport class InAppBrowserWeb extends WebPlugin {\n async open(options) {\n console.log(\"open\", options);\n return options;\n }\n async clearCookies(options) {\n console.log(\"cleanCookies\", options);\n return;\n }\n async getCookies(options) {\n // Web implementation to get cookies\n return options;\n }\n async openWebView(options) {\n console.log(\"openWebView\", options);\n return options;\n }\n async close() {\n console.log(\"close\");\n return;\n }\n async setUrl(options) {\n console.log(\"setUrl\", options.url);\n return;\n }\n async reload() {\n console.log(\"reload\");\n return;\n }\n}\n//# sourceMappingURL=web.js.map"],"names":["BackgroundColor","ToolBarType","registerPlugin","WebPlugin"],"mappings":";;;AAAWA,qCAAgB;IAC3B,CAAC,UAAU,eAAe,EAAE;IAC5B,IAAI,eAAe,CAAC,OAAO,CAAC,GAAG,OAAO,CAAC;IACvC,IAAI,eAAe,CAAC,OAAO,CAAC,GAAG,OAAO,CAAC;IACvC,CAAC,EAAEA,uBAAe,KAAKA,uBAAe,GAAG,EAAE,CAAC,CAAC,CAAC;AACnCC,iCAAY;IACvB,CAAC,UAAU,WAAW,EAAE;IACxB,IAAI,WAAW,CAAC,UAAU,CAAC,GAAG,UAAU,CAAC;IACzC,IAAI,WAAW,CAAC,YAAY,CAAC,GAAG,YAAY,CAAC;IAC7C,IAAI,WAAW,CAAC,OAAO,CAAC,GAAG,OAAO,CAAC;IACnC,IAAI,WAAW,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC;IAChC,CAAC,EAAEA,mBAAW,KAAKA,mBAAW,GAAG,EAAE,CAAC,CAAC;;ACVhC,UAAC,YAAY,GAAGC,mBAAc,CAAC,cAAc,EAAE;IACpD,IAAI,GAAG,EAAE,MAAM,mDAAe,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,IAAI,CAAC,CAAC,eAAe,EAAE,CAAC;IACnE,CAAC;;ICFM,MAAM,eAAe,SAASC,cAAS,CAAC;IAC/C,IAAI,MAAM,IAAI,CAAC,OAAO,EAAE;IACxB,QAAQ,OAAO,CAAC,GAAG,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IACrC,QAAQ,OAAO,OAAO,CAAC;IACvB,KAAK;IACL,IAAI,MAAM,YAAY,CAAC,OAAO,EAAE;IAChC,QAAQ,OAAO,CAAC,GAAG,CAAC,cAAc,EAAE,OAAO,CAAC,CAAC;IAC7C,QAAQ,OAAO;IACf,KAAK;IACL,IAAI,MAAM,UAAU,CAAC,OAAO,EAAE;IAC9B;IACA,QAAQ,OAAO,OAAO,CAAC;IACvB,KAAK;IACL,IAAI,MAAM,WAAW,CAAC,OAAO,EAAE;IAC/B,QAAQ,OAAO,CAAC,GAAG,CAAC,aAAa,EAAE,OAAO,CAAC,CAAC;IAC5C,QAAQ,OAAO,OAAO,CAAC;IACvB,KAAK;IACL,IAAI,MAAM,KAAK,GAAG;IAClB,QAAQ,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;IAC7B,QAAQ,OAAO;IACf,KAAK;IACL,IAAI,MAAM,MAAM,CAAC,OAAO,EAAE;IAC1B,QAAQ,OAAO,CAAC,GAAG,CAAC,QAAQ,EAAE,OAAO,CAAC,GAAG,CAAC,CAAC;IAC3C,QAAQ,OAAO;IACf,KAAK;IACL,IAAI,MAAM,MAAM,GAAG;IACnB,QAAQ,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;IAC9B,QAAQ,OAAO;IACf,KAAK;IACL;;;;;;;;;;;;;;;"}
|
|
1
|
+
{"version":3,"file":"plugin.js","sources":["esm/definitions.js","esm/index.js","esm/web.js"],"sourcesContent":["export var BackgroundColor;\n(function (BackgroundColor) {\n BackgroundColor[\"WHITE\"] = \"white\";\n BackgroundColor[\"BLACK\"] = \"black\";\n})(BackgroundColor || (BackgroundColor = {}));\nexport var ToolBarType;\n(function (ToolBarType) {\n ToolBarType[\"ACTIVITY\"] = \"activity\";\n ToolBarType[\"NAVIGATION\"] = \"navigation\";\n ToolBarType[\"BLANK\"] = \"blank\";\n ToolBarType[\"DEFAULT\"] = \"\";\n})(ToolBarType || (ToolBarType = {}));\n//# sourceMappingURL=definitions.js.map","import { registerPlugin } from \"@capacitor/core\";\nconst InAppBrowser = registerPlugin(\"InAppBrowser\", {\n web: () => import(\"./web\").then((m) => new m.InAppBrowserWeb()),\n});\nexport * from \"./definitions\";\nexport { InAppBrowser };\n//# sourceMappingURL=index.js.map","import { WebPlugin } from \"@capacitor/core\";\nexport class InAppBrowserWeb extends WebPlugin {\n async open(options) {\n console.log(\"open\", options);\n return options;\n }\n async clearCookies(options) {\n console.log(\"cleanCookies\", options);\n return;\n }\n async getCookies(options) {\n // Web implementation to get cookies\n return options;\n }\n async openWebView(options) {\n console.log(\"openWebView\", options);\n return options;\n }\n async executeScript({ code }) {\n console.log(\"code\", code);\n return code;\n }\n async close() {\n console.log(\"close\");\n return;\n }\n async setUrl(options) {\n console.log(\"setUrl\", options.url);\n return;\n }\n async reload() {\n console.log(\"reload\");\n return;\n }\n}\n//# sourceMappingURL=web.js.map"],"names":["BackgroundColor","ToolBarType","registerPlugin","WebPlugin"],"mappings":";;;AAAWA,qCAAgB;IAC3B,CAAC,UAAU,eAAe,EAAE;IAC5B,IAAI,eAAe,CAAC,OAAO,CAAC,GAAG,OAAO,CAAC;IACvC,IAAI,eAAe,CAAC,OAAO,CAAC,GAAG,OAAO,CAAC;IACvC,CAAC,EAAEA,uBAAe,KAAKA,uBAAe,GAAG,EAAE,CAAC,CAAC,CAAC;AACnCC,iCAAY;IACvB,CAAC,UAAU,WAAW,EAAE;IACxB,IAAI,WAAW,CAAC,UAAU,CAAC,GAAG,UAAU,CAAC;IACzC,IAAI,WAAW,CAAC,YAAY,CAAC,GAAG,YAAY,CAAC;IAC7C,IAAI,WAAW,CAAC,OAAO,CAAC,GAAG,OAAO,CAAC;IACnC,IAAI,WAAW,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC;IAChC,CAAC,EAAEA,mBAAW,KAAKA,mBAAW,GAAG,EAAE,CAAC,CAAC;;ACVhC,UAAC,YAAY,GAAGC,mBAAc,CAAC,cAAc,EAAE;IACpD,IAAI,GAAG,EAAE,MAAM,mDAAe,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,IAAI,CAAC,CAAC,eAAe,EAAE,CAAC;IACnE,CAAC;;ICFM,MAAM,eAAe,SAASC,cAAS,CAAC;IAC/C,IAAI,MAAM,IAAI,CAAC,OAAO,EAAE;IACxB,QAAQ,OAAO,CAAC,GAAG,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IACrC,QAAQ,OAAO,OAAO,CAAC;IACvB,KAAK;IACL,IAAI,MAAM,YAAY,CAAC,OAAO,EAAE;IAChC,QAAQ,OAAO,CAAC,GAAG,CAAC,cAAc,EAAE,OAAO,CAAC,CAAC;IAC7C,QAAQ,OAAO;IACf,KAAK;IACL,IAAI,MAAM,UAAU,CAAC,OAAO,EAAE;IAC9B;IACA,QAAQ,OAAO,OAAO,CAAC;IACvB,KAAK;IACL,IAAI,MAAM,WAAW,CAAC,OAAO,EAAE;IAC/B,QAAQ,OAAO,CAAC,GAAG,CAAC,aAAa,EAAE,OAAO,CAAC,CAAC;IAC5C,QAAQ,OAAO,OAAO,CAAC;IACvB,KAAK;IACL,IAAI,MAAM,aAAa,CAAC,EAAE,IAAI,EAAE,EAAE;IAClC,QAAQ,OAAO,CAAC,GAAG,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;IAClC,QAAQ,OAAO,IAAI,CAAC;IACpB,KAAK;IACL,IAAI,MAAM,KAAK,GAAG;IAClB,QAAQ,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;IAC7B,QAAQ,OAAO;IACf,KAAK;IACL,IAAI,MAAM,MAAM,CAAC,OAAO,EAAE;IAC1B,QAAQ,OAAO,CAAC,GAAG,CAAC,QAAQ,EAAE,OAAO,CAAC,GAAG,CAAC,CAAC;IAC3C,QAAQ,OAAO;IACf,KAAK;IACL,IAAI,MAAM,MAAM,GAAG;IACnB,QAAQ,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;IAC9B,QAAQ,OAAO;IACf,KAAK;IACL;;;;;;;;;;;;;;;"}
|
|
@@ -43,8 +43,8 @@ public class InAppBrowserPlugin: CAPPlugin {
|
|
|
43
43
|
#endif
|
|
44
44
|
}
|
|
45
45
|
|
|
46
|
-
func presentView() {
|
|
47
|
-
self.bridge?.viewController?.present(self.navigationWebViewController!, animated:
|
|
46
|
+
func presentView(isAnimated: Bool = true) {
|
|
47
|
+
self.bridge?.viewController?.present(self.navigationWebViewController!, animated: isAnimated, completion: {
|
|
48
48
|
self.currentPluginCall?.resolve()
|
|
49
49
|
})
|
|
50
50
|
}
|
|
@@ -52,6 +52,11 @@ public class InAppBrowserPlugin: CAPPlugin {
|
|
|
52
52
|
@objc func clearCookies(_ call: CAPPluginCall) {
|
|
53
53
|
let dataStore = WKWebsiteDataStore.default()
|
|
54
54
|
let urlString = call.getString("url") ?? ""
|
|
55
|
+
let clearCache = call.getBool("cache") ?? false
|
|
56
|
+
|
|
57
|
+
if clearCache {
|
|
58
|
+
URLCache.shared.removeAllCachedResponses()
|
|
59
|
+
}
|
|
55
60
|
|
|
56
61
|
guard let url = URL(string: urlString), let hostName = url.host else {
|
|
57
62
|
call.reject("Invalid URL")
|
|
@@ -113,6 +118,8 @@ public class InAppBrowserPlugin: CAPPlugin {
|
|
|
113
118
|
let closeModalDescription = call.getString("closeModalDescription", "Are you sure you want to close this window?")
|
|
114
119
|
let closeModalOk = call.getString("closeModalOk", "OK")
|
|
115
120
|
let closeModalCancel = call.getString("closeModalCancel", "Cancel")
|
|
121
|
+
let isInspectable = call.getBool("isInspectable", false)
|
|
122
|
+
let isAnimated = call.getBool("isAnimated", true)
|
|
116
123
|
|
|
117
124
|
var disclaimerContent = call.getObject("shareDisclaimer")
|
|
118
125
|
let toolbarType = call.getString("toolbarType", "")
|
|
@@ -128,7 +135,7 @@ public class InAppBrowserPlugin: CAPPlugin {
|
|
|
128
135
|
let url = URL(string: urlString)
|
|
129
136
|
|
|
130
137
|
if self.isPresentAfterPageLoad {
|
|
131
|
-
self.webViewController = WKWebViewController.init(url: url!, headers: headers)
|
|
138
|
+
self.webViewController = WKWebViewController.init(url: url!, headers: headers, isInspectable: isInspectable)
|
|
132
139
|
} else {
|
|
133
140
|
self.webViewController = WKWebViewController.init()
|
|
134
141
|
self.webViewController?.setHeaders(headers: headers)
|
|
@@ -169,7 +176,7 @@ public class InAppBrowserPlugin: CAPPlugin {
|
|
|
169
176
|
self.webViewController?.leftNavigaionBarItemTypes = toolbarItems + [.reload]
|
|
170
177
|
}
|
|
171
178
|
if !self.isPresentAfterPageLoad {
|
|
172
|
-
self.presentView()
|
|
179
|
+
self.presentView(isAnimated: isAnimated)
|
|
173
180
|
}
|
|
174
181
|
}
|
|
175
182
|
}
|
|
@@ -199,6 +206,14 @@ public class InAppBrowserPlugin: CAPPlugin {
|
|
|
199
206
|
call.resolve()
|
|
200
207
|
}
|
|
201
208
|
|
|
209
|
+
@objc func executeScript(_ call: CAPPluginCall) {
|
|
210
|
+
guard let script = call.getString("code") else {
|
|
211
|
+
call.reject("Cannot get script to execute")
|
|
212
|
+
return
|
|
213
|
+
}
|
|
214
|
+
self.webViewController?.executeScript(script: script)
|
|
215
|
+
}
|
|
216
|
+
|
|
202
217
|
func isHexColorCode(_ input: String) -> Bool {
|
|
203
218
|
let hexColorRegex = "^#([0-9A-Fa-f]{3}|[0-9A-Fa-f]{6})$"
|
|
204
219
|
|
|
@@ -220,6 +235,8 @@ public class InAppBrowserPlugin: CAPPlugin {
|
|
|
220
235
|
self.setup()
|
|
221
236
|
}
|
|
222
237
|
|
|
238
|
+
let isInspectable = call.getBool("isInspectable", false)
|
|
239
|
+
|
|
223
240
|
self.currentPluginCall = call
|
|
224
241
|
|
|
225
242
|
guard let urlString = call.getString("url") else {
|
|
@@ -240,7 +257,7 @@ public class InAppBrowserPlugin: CAPPlugin {
|
|
|
240
257
|
let url = URL(string: urlString)
|
|
241
258
|
|
|
242
259
|
if self.isPresentAfterPageLoad {
|
|
243
|
-
self.webViewController = WKWebViewController.init(url: url!, headers: headers)
|
|
260
|
+
self.webViewController = WKWebViewController.init(url: url!, headers: headers, isInspectable: isInspectable)
|
|
244
261
|
} else {
|
|
245
262
|
self.webViewController = WKWebViewController.init()
|
|
246
263
|
self.webViewController?.setHeaders(headers: headers)
|
|
@@ -60,11 +60,11 @@ open class WKWebViewController: UIViewController {
|
|
|
60
60
|
self.initWebview()
|
|
61
61
|
}
|
|
62
62
|
|
|
63
|
-
public init(url: URL, headers: [String: String]) {
|
|
63
|
+
public init(url: URL, headers: [String: String], isInspectable: Bool) {
|
|
64
64
|
super.init(nibName: nil, bundle: nil)
|
|
65
65
|
self.source = .remote(url)
|
|
66
66
|
self.setHeaders(headers: headers)
|
|
67
|
-
self.initWebview()
|
|
67
|
+
self.initWebview(isInspectable: isInspectable)
|
|
68
68
|
}
|
|
69
69
|
|
|
70
70
|
open var hasDynamicTitle = false
|
|
@@ -206,7 +206,7 @@ open class WKWebViewController: UIViewController {
|
|
|
206
206
|
}
|
|
207
207
|
}
|
|
208
208
|
|
|
209
|
-
open func initWebview() {
|
|
209
|
+
open func initWebview(isInspectable: Bool = true) {
|
|
210
210
|
|
|
211
211
|
self.view.backgroundColor = UIColor.white
|
|
212
212
|
|
|
@@ -216,6 +216,10 @@ open class WKWebViewController: UIViewController {
|
|
|
216
216
|
let webConfiguration = WKWebViewConfiguration()
|
|
217
217
|
let webView = WKWebView(frame: .zero, configuration: webConfiguration)
|
|
218
218
|
|
|
219
|
+
if #available(iOS 16.4, *) {
|
|
220
|
+
webView.isInspectable = isInspectable
|
|
221
|
+
}
|
|
222
|
+
|
|
219
223
|
webView.uiDelegate = self
|
|
220
224
|
webView.navigationDelegate = self
|
|
221
225
|
|
|
@@ -241,8 +245,6 @@ open class WKWebViewController: UIViewController {
|
|
|
241
245
|
self.previousToolbarState = (navigation.toolbar.tintColor, navigation.toolbar.isHidden)
|
|
242
246
|
}
|
|
243
247
|
|
|
244
|
-
// self.restateViewHeight()
|
|
245
|
-
|
|
246
248
|
if let s = self.source {
|
|
247
249
|
self.load(source: s)
|
|
248
250
|
} else {
|
|
@@ -376,6 +378,10 @@ public extension WKWebViewController {
|
|
|
376
378
|
func reload() {
|
|
377
379
|
webView?.reload()
|
|
378
380
|
}
|
|
381
|
+
|
|
382
|
+
func executeScript(script: String, completion: ((Any?, Error?) -> Void)? = nil) {
|
|
383
|
+
webView?.evaluateJavaScript(script, completionHandler: completion)
|
|
384
|
+
}
|
|
379
385
|
}
|
|
380
386
|
|
|
381
387
|
// MARK: - Fileprivate Methods
|