2018-10-15 23:27:58 +00:00
|
|
|
import 'dart:async';
|
2018-10-17 23:22:47 +00:00
|
|
|
import 'dart:convert' show base64;
|
2018-09-14 00:21:51 +00:00
|
|
|
import 'package:flutter/material.dart';
|
|
|
|
import 'package:flutter_inappbrowser/flutter_inappbrowser.dart';
|
|
|
|
|
|
|
|
class MyInAppBrowser extends InAppBrowser {
|
|
|
|
@override
|
2018-09-23 16:35:32 +00:00
|
|
|
Future onLoadStart(String url) async {
|
2018-10-05 11:18:28 +00:00
|
|
|
print("\n\nStarted $url\n\n");
|
2018-09-23 16:35:32 +00:00
|
|
|
//print("\n\n ${await this.isHidden()} \n\n");
|
2018-09-14 00:21:51 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
@override
|
2018-09-23 16:35:32 +00:00
|
|
|
Future onLoadStop(String url) async {
|
2018-10-05 11:18:28 +00:00
|
|
|
print("\n\nStopped $url\n\n");
|
2018-10-09 23:52:27 +00:00
|
|
|
|
2018-10-17 23:22:47 +00:00
|
|
|
// var screenshot = await this.takeScreenshot();
|
|
|
|
// await this.injectScriptCode("""
|
|
|
|
// document.body.innerHTML = '<img style="max-width: 100%; width: 100%" src="data:image/png;base64,${base64.encode(screenshot)}" />';
|
|
|
|
// """);
|
|
|
|
|
|
|
|
// var options = await this.getOptions();
|
|
|
|
// if (options["javaScriptEnabled"]) {
|
|
|
|
// await this.setOptions({
|
|
|
|
// //"progressBar": true,
|
|
|
|
// //"useOnLoadResource": true,
|
|
|
|
// //"hidden": true,
|
|
|
|
// //"toolbarTopFixedTitle": "Fixed title A",
|
|
|
|
// //"useShouldOverrideUrlLoading": true
|
|
|
|
// //"hideUrlBar": true,
|
|
|
|
// "javaScriptEnabled": false,
|
|
|
|
// "toolbarTop": true,
|
|
|
|
// "toolbarBottom": false
|
|
|
|
// });
|
|
|
|
// }
|
|
|
|
// else {
|
|
|
|
// await this.setOptions({
|
|
|
|
// //"progressBar": false,
|
|
|
|
// //"useOnLoadResource": false,
|
|
|
|
// //"hidden": true,
|
|
|
|
// //"toolbarTopFixedTitle": "Fixed title B",
|
|
|
|
// //"useShouldOverrideUrlLoading": true
|
|
|
|
// //"hideUrlBar": false,
|
|
|
|
// "javaScriptEnabled": true,
|
|
|
|
// "toolbarTop": false,
|
|
|
|
// "toolbarBottom": true
|
|
|
|
// });
|
|
|
|
// }
|
|
|
|
|
|
|
|
// print("\n\n ${await this.isHidden()} \n\n");
|
2018-10-15 23:27:58 +00:00
|
|
|
|
2018-10-13 19:14:31 +00:00
|
|
|
// await this.injectScriptCode("window.flutter_inappbrowser.callHandler('handlerTest', 1, 5,'string', {'key': 5}, [4,6,8]);");
|
|
|
|
// await this.injectScriptCode("window.flutter_inappbrowser.callHandler('handlerTest2', false, null, undefined);");
|
|
|
|
// await this.injectScriptCode("setTimeout(function(){window.flutter_inappbrowser.callHandler('handlerTest', 'anotherString');}, 1000);");
|
2018-10-09 23:52:27 +00:00
|
|
|
//
|
|
|
|
// await this.injectScriptCode("console.log({'testObject': 5});");
|
|
|
|
// await this.injectScriptCode("console.warn('testWarn',null);");
|
|
|
|
// await this.injectScriptCode("console.log('testObjectStringify', JSON.stringify({'asd': 5}));");
|
|
|
|
// await this.injectScriptCode("console.info('testInfo', 6);");
|
|
|
|
// await this.injectScriptCode("console.error('testError', false);");
|
|
|
|
// await this.injectScriptCode("console.debug('testDebug', true);");
|
2018-10-17 23:22:47 +00:00
|
|
|
|
2018-09-23 16:35:32 +00:00
|
|
|
// print(await this.injectScriptCode("document.body.innerHTML"));
|
2018-10-17 23:22:47 +00:00
|
|
|
|
2018-10-09 23:52:27 +00:00
|
|
|
// print(await this.injectScriptCode("null"));
|
|
|
|
// print(await this.injectScriptCode("undefined"));
|
2018-09-23 16:35:32 +00:00
|
|
|
// print(await this.injectScriptCode("3"));
|
|
|
|
// print(await this.injectScriptCode("""
|
|
|
|
// function asd (a,b) {
|
|
|
|
// return a+b;
|
|
|
|
// };
|
|
|
|
// asd(3,5);
|
|
|
|
// """));
|
|
|
|
// print(await this.injectScriptCode("""
|
|
|
|
// ["3",56,"sdf"];
|
|
|
|
// """));
|
|
|
|
// print(await this.injectScriptCode("""
|
|
|
|
// var x = {"as":4, "dfdfg": 6};
|
|
|
|
// x;
|
|
|
|
// """));
|
2018-10-15 23:27:58 +00:00
|
|
|
//
|
2018-09-23 23:53:22 +00:00
|
|
|
// await this.injectScriptFile("https://code.jquery.com/jquery-3.3.1.min.js");
|
|
|
|
// this.injectScriptCode("""
|
|
|
|
// \$( "body" ).html( "Next Step..." )
|
|
|
|
// """);
|
|
|
|
//
|
|
|
|
// // add custom css
|
|
|
|
// this.injectStyleCode("""
|
|
|
|
// body {
|
|
|
|
// background-color: #3c3c3c !important;
|
|
|
|
// }
|
|
|
|
// """);
|
|
|
|
// this.injectStyleFile("https://stackpath.bootstrapcdn.com/bootstrap/4.1.3/css/bootstrap.min.css");
|
2018-09-14 00:21:51 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
@override
|
2018-09-22 12:54:21 +00:00
|
|
|
void onLoadError(String url, int code, String message) {
|
2018-09-14 00:21:51 +00:00
|
|
|
print("\n\nCan't load $url.. Error: $message\n\n");
|
|
|
|
}
|
|
|
|
|
|
|
|
@override
|
|
|
|
void onExit() {
|
|
|
|
print("\n\nBrowser closed!\n\n");
|
|
|
|
}
|
|
|
|
|
2018-09-23 19:38:31 +00:00
|
|
|
@override
|
|
|
|
void shouldOverrideUrlLoading(String url) {
|
|
|
|
print("\n\n override $url\n\n");
|
|
|
|
this.loadUrl(url);
|
|
|
|
}
|
2018-10-09 23:52:27 +00:00
|
|
|
|
2018-10-12 01:46:33 +00:00
|
|
|
@override
|
2018-10-15 23:27:58 +00:00
|
|
|
void onLoadResource(
|
|
|
|
WebResourceResponse response, WebResourceRequest request) {
|
|
|
|
print("Started at: " +
|
|
|
|
response.startTime.toString() +
|
|
|
|
"ms ---> duration: " +
|
|
|
|
response.duration.toString() +
|
|
|
|
"ms " +
|
|
|
|
response.url);
|
2018-10-13 19:12:32 +00:00
|
|
|
// if (response.headers["content-length"] != null)
|
|
|
|
// print(response.headers["content-length"] + " length");
|
2018-10-12 01:46:33 +00:00
|
|
|
}
|
|
|
|
|
2018-10-09 23:52:27 +00:00
|
|
|
@override
|
|
|
|
void onConsoleMessage(ConsoleMessage consoleMessage) {
|
2018-10-17 23:22:47 +00:00
|
|
|
print(consoleMessage.message);
|
|
|
|
// print("""
|
|
|
|
// console output:
|
|
|
|
// sourceURL: ${consoleMessage.sourceURL}
|
|
|
|
// lineNumber: ${consoleMessage.lineNumber}
|
|
|
|
// message: ${consoleMessage.message}
|
|
|
|
// messageLevel: ${consoleMessage.messageLevel}
|
|
|
|
// """);
|
2018-10-09 23:52:27 +00:00
|
|
|
}
|
2018-09-14 00:21:51 +00:00
|
|
|
}
|
|
|
|
|
2018-09-26 00:56:56 +00:00
|
|
|
MyInAppBrowser inAppBrowserFallback = new MyInAppBrowser();
|
|
|
|
|
|
|
|
class MyChromeSafariBrowser extends ChromeSafariBrowser {
|
|
|
|
MyChromeSafariBrowser(browserFallback) : super(browserFallback);
|
|
|
|
|
|
|
|
@override
|
|
|
|
void onOpened() {
|
|
|
|
print("ChromeSafari browser opened");
|
|
|
|
}
|
|
|
|
|
|
|
|
@override
|
|
|
|
void onLoaded() {
|
|
|
|
print("ChromeSafari browser loaded");
|
|
|
|
}
|
|
|
|
|
|
|
|
@override
|
|
|
|
void onClosed() {
|
|
|
|
print("ChromeSafari browser closed");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-10-13 19:12:32 +00:00
|
|
|
// adding a webview fallback
|
2018-10-15 23:27:58 +00:00
|
|
|
MyChromeSafariBrowser chromeSafariBrowser =
|
|
|
|
new MyChromeSafariBrowser(inAppBrowserFallback);
|
2018-09-14 00:21:51 +00:00
|
|
|
|
2018-10-15 23:27:58 +00:00
|
|
|
Future main() async {
|
2018-10-13 19:12:32 +00:00
|
|
|
runApp(new MyApp());
|
|
|
|
}
|
2018-09-14 00:21:51 +00:00
|
|
|
|
|
|
|
class MyApp extends StatefulWidget {
|
|
|
|
@override
|
|
|
|
_MyAppState createState() => new _MyAppState();
|
|
|
|
}
|
|
|
|
|
|
|
|
class _MyAppState extends State<MyApp> {
|
|
|
|
@override
|
|
|
|
void initState() {
|
|
|
|
super.initState();
|
2018-10-15 23:27:58 +00:00
|
|
|
// int indexTest = inAppBrowserFallback.addJavaScriptHandler("handlerTest",
|
|
|
|
// (arguments) async {
|
2018-10-13 19:14:31 +00:00
|
|
|
// print("handlerTest arguments");
|
|
|
|
// print(arguments);
|
|
|
|
// });
|
|
|
|
// int indexTest2 = inAppBrowserFallback.addJavaScriptHandler("test2", (arguments) async {
|
|
|
|
// print("handlerTest2 arguments");
|
|
|
|
// print(arguments);
|
|
|
|
// inAppBrowserFallback.removeJavaScriptHandler("test", indexTest);
|
|
|
|
// });
|
2018-09-14 00:21:51 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
@override
|
|
|
|
Widget build(BuildContext context) {
|
|
|
|
return new MaterialApp(
|
|
|
|
home: new Scaffold(
|
|
|
|
appBar: new AppBar(
|
2018-09-14 00:41:43 +00:00
|
|
|
title: const Text('Flutter InAppBrowser Plugin example app'),
|
2018-09-14 00:21:51 +00:00
|
|
|
),
|
|
|
|
body: new Center(
|
2018-10-15 23:27:58 +00:00
|
|
|
child: new RaisedButton(
|
|
|
|
onPressed: () async {
|
|
|
|
// await chromeSafariBrowser.open("https://flutter.io/");
|
|
|
|
|
|
|
|
// await InAppBrowser.openWithSystemBrowser("https://flutter.io/");
|
|
|
|
|
2018-10-17 23:22:47 +00:00
|
|
|
// await inAppBrowserFallback.openOnLocalhost("assets/index.html", options: {
|
2018-10-15 23:27:58 +00:00
|
|
|
// "useOnLoadResource": true,
|
|
|
|
// //"hidden": true,
|
|
|
|
// //"toolbarTopFixedTitle": "Fixed title",
|
|
|
|
// //"useShouldOverrideUrlLoading": true
|
|
|
|
// //"hideUrlBar": true,
|
|
|
|
// //"toolbarTop": false,
|
|
|
|
// //"toolbarBottom": false
|
|
|
|
// });
|
|
|
|
|
2018-10-17 23:22:47 +00:00
|
|
|
// await inAppBrowserFallback.open(url: "assets/index.html", options: {
|
|
|
|
// "isLocalFile": true,
|
|
|
|
// "useOnLoadResource": true,
|
2018-10-15 23:27:58 +00:00
|
|
|
// //"hidden": true,
|
|
|
|
// //"toolbarTopFixedTitle": "Fixed title",
|
|
|
|
// //"useShouldOverrideUrlLoading": true
|
|
|
|
// //"hideUrlBar": true,
|
|
|
|
// //"toolbarTop": false,
|
|
|
|
// //"toolbarBottom": false
|
|
|
|
// });
|
2018-10-17 23:22:47 +00:00
|
|
|
|
|
|
|
await inAppBrowserFallback.open(url: "https://flutter.io/", options: {
|
|
|
|
//"useOnLoadResource": true,
|
|
|
|
//"hidden": true,
|
|
|
|
//"toolbarTopFixedTitle": "Fixed title",
|
|
|
|
//"useShouldOverrideUrlLoading": true
|
|
|
|
//"hideUrlBar": true,
|
|
|
|
//"toolbarTop": false,
|
|
|
|
//"toolbarBottom": false
|
|
|
|
});
|
2018-10-15 23:27:58 +00:00
|
|
|
//await inAppBrowserFallback.openOnLocalhost("assets/index.html");
|
|
|
|
},
|
|
|
|
child: Text("Open InAppBrowser")),
|
2018-09-14 00:21:51 +00:00
|
|
|
),
|
|
|
|
),
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|