2019-11-16 18:54:03 +00:00
|
|
|
import 'dart:convert';
|
|
|
|
|
|
|
|
import 'package:flutter/material.dart';
|
|
|
|
|
2019-11-29 15:59:18 +00:00
|
|
|
import 'package:flutter_inappwebview/flutter_inappwebview.dart';
|
2019-11-16 18:54:03 +00:00
|
|
|
|
|
|
|
import 'main_test.dart';
|
|
|
|
import 'custom_widget_test.dart';
|
2019-11-25 00:42:27 +00:00
|
|
|
import '.env.dart';
|
2019-11-16 18:54:03 +00:00
|
|
|
|
|
|
|
class InAppWebViewFetchTest extends WidgetTest {
|
|
|
|
final InAppWebViewFetchTestState state = InAppWebViewFetchTestState();
|
|
|
|
|
|
|
|
@override
|
|
|
|
InAppWebViewFetchTestState createState() => state;
|
|
|
|
}
|
|
|
|
|
|
|
|
class InAppWebViewFetchTestState extends WidgetTestState {
|
|
|
|
String appBarTitle = "InAppWebViewFetchTest";
|
|
|
|
int totTests = 2;
|
|
|
|
int testsDone = 0;
|
|
|
|
|
|
|
|
@override
|
|
|
|
Widget build(BuildContext context) {
|
|
|
|
return Scaffold(
|
2019-11-25 00:42:27 +00:00
|
|
|
key: this.scaffoldKey,
|
2019-11-16 18:54:03 +00:00
|
|
|
appBar: myAppBar(state: this, title: appBarTitle),
|
2019-11-25 00:42:27 +00:00
|
|
|
drawer: myDrawer(context: context),
|
2019-11-16 18:54:03 +00:00
|
|
|
body: Container(
|
|
|
|
child: Column(children: <Widget>[
|
|
|
|
Expanded(
|
|
|
|
child: Container(
|
|
|
|
child: InAppWebView(
|
2019-11-25 00:42:27 +00:00
|
|
|
initialData: InAppWebViewInitialData(data: """
|
|
|
|
<!doctype html>
|
|
|
|
<html lang="en">
|
|
|
|
<head>
|
|
|
|
<meta charset="UTF-8">
|
|
|
|
<meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
|
|
|
|
<meta http-equiv="X-UA-Compatible" content="ie=edge">
|
|
|
|
<title>InAppWebViewFetchTest</title>
|
|
|
|
</head>
|
|
|
|
<body>
|
|
|
|
<h1>InAppWebViewFetchTest</h1>
|
|
|
|
<script>
|
2019-11-29 15:59:18 +00:00
|
|
|
window.addEventListener('flutterInAppWebViewPlatformReady', function(event) {
|
2019-11-25 00:42:27 +00:00
|
|
|
fetch(new Request("http://${environment["NODE_SERVER_IP"]}:8082/test-download-file")).then(function(response) {
|
2019-11-29 15:59:18 +00:00
|
|
|
window.flutter_inappwebview.callHandler('fetchGet', response.status);
|
2019-11-25 00:42:27 +00:00
|
|
|
}).catch(function(error) {
|
2019-11-29 15:59:18 +00:00
|
|
|
window.flutter_inappwebview.callHandler('fetchGet', "ERROR: " + error);
|
2019-11-25 00:42:27 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
fetch("http://${environment["NODE_SERVER_IP"]}:8082/test-ajax-post", {
|
|
|
|
method: 'POST',
|
|
|
|
body: JSON.stringify({
|
|
|
|
firstname: 'Foo',
|
|
|
|
lastname: 'Bar'
|
|
|
|
}),
|
|
|
|
headers: {
|
|
|
|
'Content-Type': 'application/json'
|
|
|
|
}
|
|
|
|
}).then(function(response) {
|
|
|
|
response.json().then(function(value) {
|
2019-11-29 15:59:18 +00:00
|
|
|
window.flutter_inappwebview.callHandler('fetchPost', value);
|
2019-11-25 00:42:27 +00:00
|
|
|
}).catch(function(error) {
|
2019-11-29 15:59:18 +00:00
|
|
|
window.flutter_inappwebview.callHandler('fetchPost', "ERROR: " + error);
|
2019-11-25 00:42:27 +00:00
|
|
|
});
|
|
|
|
}).catch(function(error) {
|
2019-11-29 15:59:18 +00:00
|
|
|
window.flutter_inappwebview.callHandler('fetchPost', "ERROR: " + error);
|
2019-11-25 00:42:27 +00:00
|
|
|
});
|
|
|
|
});
|
|
|
|
</script>
|
|
|
|
</body>
|
|
|
|
</html>
|
|
|
|
"""),
|
2019-11-16 18:54:03 +00:00
|
|
|
initialHeaders: {},
|
|
|
|
initialOptions: InAppWebViewWidgetOptions(
|
|
|
|
inAppWebViewOptions: InAppWebViewOptions(
|
|
|
|
clearCache: true,
|
|
|
|
debuggingEnabled: true,
|
|
|
|
useShouldInterceptFetchRequest: true,
|
|
|
|
)
|
|
|
|
),
|
|
|
|
onWebViewCreated: (InAppWebViewController controller) {
|
|
|
|
webView = controller;
|
|
|
|
|
|
|
|
webView.addJavaScriptHandler(handlerName: "fetchGet", callback: (args) {
|
|
|
|
appBarTitle = (appBarTitle == "InAppWebViewFetchTest") ? args[0].toString() : appBarTitle + " " + args[0].toString();
|
|
|
|
updateCountTest(context: context);
|
|
|
|
});
|
|
|
|
|
|
|
|
webView.addJavaScriptHandler(handlerName: "fetchPost", callback: (args) {
|
|
|
|
appBarTitle = (appBarTitle == "InAppWebViewFetchTest") ? args[0]["fullname"] : appBarTitle + " " + args[0]["fullname"];
|
|
|
|
updateCountTest(context: context);
|
|
|
|
});
|
|
|
|
},
|
|
|
|
onLoadStart: (InAppWebViewController controller, String url) {
|
|
|
|
|
|
|
|
},
|
|
|
|
onLoadStop: (InAppWebViewController controller, String url) {
|
|
|
|
|
|
|
|
},
|
|
|
|
shouldInterceptFetchRequest: (InAppWebViewController controller, FetchRequest fetchRequest) async {
|
|
|
|
if (fetchRequest.url.endsWith("/test-ajax-post")) {
|
|
|
|
fetchRequest.body = utf8.encode("""{
|
|
|
|
"firstname": "Lorenzo",
|
|
|
|
"lastname": "Pichilli"
|
|
|
|
}
|
|
|
|
""");
|
|
|
|
}
|
|
|
|
return fetchRequest;
|
|
|
|
},
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
])
|
|
|
|
)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
void updateCountTest({@required BuildContext context}) {
|
|
|
|
testsDone++;
|
|
|
|
if (testsDone == totTests) {
|
|
|
|
setState(() { });
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|