WIP: add iosController in fastpass
This commit is contained in:
parent
fd85a0cfdf
commit
ea6c2226cb
|
@ -18,7 +18,8 @@ class FastPassPageWidget extends StatefulWidget {
|
|||
}
|
||||
|
||||
class _FastPassPageWidgetState extends State<FastPassPageWidget> {
|
||||
late WebViewController _controllerAll;
|
||||
late WebViewController _controllerAndroid;
|
||||
late InAppWebViewController _controllerIOS;
|
||||
|
||||
Future<Map<String, String>> initVariables() async {
|
||||
final email = StorageUtil().email;
|
||||
|
@ -67,31 +68,19 @@ class _FastPassPageWidgetState extends State<FastPassPageWidget> {
|
|||
return Platform.isIOS
|
||||
? InAppWebView(
|
||||
initialUrlRequest: URLRequest(url: WebUri(url)),
|
||||
initialSettings: InAppWebViewSettings(
|
||||
allowsBackForwardNavigationGestures: true,
|
||||
javaScriptEnabled: true,
|
||||
),
|
||||
onWebViewCreated: (controller) async {
|
||||
},
|
||||
initialSettings: InAppWebViewSettings(allowsBackForwardNavigationGestures: true, javaScriptEnabled: true,),
|
||||
onWebViewCreated: (controller) async => _controllerIOS = controller,
|
||||
onLoadStop: (controller, url) async {
|
||||
await controller.evaluateJavascript(
|
||||
source:
|
||||
"window.localStorage.setItem('fre-token', '\"$userUUID\"')");
|
||||
await controller.evaluateJavascript(
|
||||
source:
|
||||
"window.localStorage.setItem('fre-user-data', '$freUserData')");
|
||||
await controller.evaluateJavascript(
|
||||
source:
|
||||
"window.localStorage.setItem('enableBackButton', 'true')");
|
||||
await controller.evaluateJavascript(source: "window.localStorage.setItem('fre-token', '\"$userUUID\"')");
|
||||
await controller.evaluateJavascript(source: "window.localStorage.setItem('fre-user-data', '$freUserData')");
|
||||
await controller.evaluateJavascript(source: "window.localStorage.setItem('enableBackButton', 'true')");
|
||||
},
|
||||
onUpdateVisitedHistory: (controller, uri, isVisited) {
|
||||
if (uri.toString().contains('/hub/home')) {
|
||||
context.pop();
|
||||
}
|
||||
if (uri.toString().contains('/hub/home')) context.pop();
|
||||
},
|
||||
)
|
||||
: WebViewWidget(
|
||||
controller: _controllerAll = WebViewController()
|
||||
controller: _controllerAndroid = WebViewController()
|
||||
..clearCache()
|
||||
..clearLocalStorage()
|
||||
..setJavaScriptMode(JavaScriptMode.unrestricted)
|
||||
|
@ -100,33 +89,27 @@ class _FastPassPageWidgetState extends State<FastPassPageWidget> {
|
|||
NavigationDelegate(
|
||||
onProgress: (int progress) {},
|
||||
onPageStarted: (String url) {
|
||||
final String token =
|
||||
"localStorage.setItem('fre-token', '\"$userUUID\"');";
|
||||
final String data =
|
||||
"localStorage.setItem('fre-user-data', '$freUserData');";
|
||||
const String backNavigation =
|
||||
"localStorage.setItem('enableBackButton', 'true');";
|
||||
final String token = "localStorage.setItem('fre-token', '\"$userUUID\"');";
|
||||
final String data = "localStorage.setItem('fre-user-data', '$freUserData');";
|
||||
const String backNavigation = "localStorage.setItem('enableBackButton', 'true');";
|
||||
|
||||
_controllerAll.runJavaScript(token);
|
||||
_controllerAll.runJavaScript(data);
|
||||
_controllerAll.runJavaScript(backNavigation);
|
||||
_controllerAndroid.runJavaScript(token);
|
||||
_controllerAndroid.runJavaScript(data);
|
||||
_controllerAndroid.runJavaScript(backNavigation);
|
||||
},
|
||||
onPageFinished: (String url) {
|
||||
bool isDarkMode = SchedulerBinding
|
||||
.instance
|
||||
.platformDispatcher
|
||||
.platformBrightness ==
|
||||
Brightness.dark;
|
||||
.platformBrightness == Brightness.dark;
|
||||
|
||||
if (isDarkMode) {
|
||||
_controllerAll.runJavaScript(
|
||||
WebviewUtil.jsEnableDarkMode);
|
||||
_controllerAndroid.runJavaScript(WebviewUtil.jsEnableDarkMode);
|
||||
}
|
||||
},
|
||||
onNavigationRequest: (NavigationRequest request) {
|
||||
if (request.url.startsWith('http') ||
|
||||
request.url.startsWith(
|
||||
'https://api.whatsapp.com/send') ||
|
||||
request.url.startsWith('https://api.whatsapp.com/send') ||
|
||||
request.url.startsWith('https://wa.me')) {
|
||||
launchUrlString(request.url);
|
||||
return NavigationDecision.prevent;
|
||||
|
@ -134,9 +117,7 @@ class _FastPassPageWidgetState extends State<FastPassPageWidget> {
|
|||
return NavigationDecision.prevent;
|
||||
},
|
||||
onUrlChange: (url) {
|
||||
if (url.url.toString().contains('/hub/home')) {
|
||||
context.pop();
|
||||
}
|
||||
if (url.url.toString().contains('/hub/home')) context.pop();
|
||||
}),
|
||||
)
|
||||
..loadRequest(Uri.parse(url)),
|
||||
|
|
Loading…
Reference in New Issue