1- <img src="https://img.shields.io/badge/Flutter%20Communityflutter__webview__plugin-blue.svg?style=for-the-badge&logo=" width="800">
2-
3- [ Flutter Community] ( https://github.com/fluttercommunity/community )
1+ [ ![ Flutter Community: flutter_webview_plugin] ( https://fluttercommunity.dev/_github/header/flutter_webview_plugin )] ( https://github.com/fluttercommunity/community )
42
53# Flutter WebView Plugin
64
@@ -10,12 +8,32 @@ Plugin that allows Flutter to communicate with a native WebView.
108
119** _ Warning:_ **
1210The webview is not integrated in the widget tree, it is a native view on top of the flutter view.
13- you won't be able to use snackbars, dialogs ...
11+ You won't be able see snackbars, dialogs, or other flutter widgets that would overlap with the region of the screen taken up by the webview.
12+
13+ The getSafeAcceptedType() function is available only for minimum SDK of 21.
14+ eval() function only supports SDK of 19 or greater for evaluating Javascript.
1415
1516## Getting Started
1617
1718For help getting started with Flutter, view our online [ documentation] ( http://flutter.io/ ) .
1819
20+ #### iOS
21+
22+ In order for plugin to work correctly, you need to add new key to ` ios/Runner/Info.plist `
23+
24+ ``` xml
25+ <key >NSAppTransportSecurity</key >
26+ <dict >
27+ <key >NSAllowsArbitraryLoads</key >
28+ <true />
29+ <key >NSAllowsArbitraryLoadsInWebContent</key >
30+ <true />
31+ </dict >
32+ ```
33+
34+ ` NSAllowsArbitraryLoadsInWebContent ` is for iOS 10+ and ` NSAllowsArbitraryLoads ` for iOS 9.
35+
36+
1937### How it works
2038
2139#### Launch WebView Fullscreen with Flutter navigation
@@ -125,6 +143,25 @@ flutterWebviewPlugin.launch(url,
125143);
126144```
127145
146+ #### Injecting custom code into the webview
147+ Use ` flutterWebviewPlugin.evalJavaScript(String code) ` . This function must be run after the page has finished loading (i.e. listen to ` onStateChanged ` for events where state is ` finishLoad ` ).
148+
149+ If you have a large amount of JavaScript to embed, use an asset file. Add the asset file to ` pubspec.yaml ` , then call the function like:
150+
151+ ``` dart
152+ Future<String> loadJS(String name) async {
153+ var givenJS = rootBundle.loadString('assets/$name.js');
154+ return givenJS.then((String js) {
155+ flutterWebViewPlugin.onStateChanged.listen((viewState) async {
156+ if (viewState.type == WebViewState.finishLoad) {
157+ flutterWebViewPlugin.evalJavascript(js);
158+ }
159+ });
160+ });
161+ }
162+ ```
163+
164+
128165### Webview Events
129166
130167- ` Stream<Null> ` onDestroy
0 commit comments