import { WebViewBase, knownFolders, traceWrite, traceEnabled, traceCategories, NavigationType } from "./web-view-common"; import { profile } from "../../profiling"; import { layout } from "../core/view"; export * from "./web-view-common"; class WKNavigationDelegateImpl extends NSObject implements WKNavigationDelegate { public static ObjCProtocols = [WKNavigationDelegate]; public static initWithOwner(owner: WeakRef): WKNavigationDelegateImpl { const handler = WKNavigationDelegateImpl.new(); handler._owner = owner; return handler; } private _owner: WeakRef; public webViewDecidePolicyForNavigationActionDecisionHandler(webView: WKWebView, navigationAction: WKNavigationAction, decisionHandler: any): void { const owner = this._owner.get(); if (owner && navigationAction.request.URL) { let navType: NavigationType = "other"; switch (navigationAction.navigationType) { case WKNavigationType.LinkActivated: navType = "linkClicked"; break; case WKNavigationType.FormSubmitted: navType = "formSubmitted"; break; case WKNavigationType.BackForward: navType = "backForward"; break; case WKNavigationType.Reload: navType = "reload"; break; case WKNavigationType.FormResubmitted: navType = "formResubmitted"; break; } decisionHandler(WKNavigationActionPolicy.Allow); if (traceEnabled()) { traceWrite("WKNavigationDelegateClass.webViewDecidePolicyForNavigationActionDecisionHandler(" + navigationAction.request.URL.absoluteString + ", " + navigationAction.navigationType + ")", traceCategories.Debug); } owner._onLoadStarted(navigationAction.request.URL.absoluteString, navType); } } public webViewDidStartProvisionalNavigation(webView: WKWebView, navigation: WKNavigation): void { if (traceEnabled()) { traceWrite("WKNavigationDelegateClass.webViewDidStartProvisionalNavigation(" + webView.URL + ")", traceCategories.Debug); } }; public webViewDidFinishNavigation(webView: WKWebView, navigation: WKNavigation): void { if (traceEnabled()) { traceWrite("WKNavigationDelegateClass.webViewDidFinishNavigation(" + webView.URL + ")", traceCategories.Debug); } const owner = this._owner.get(); if (owner) { webView.evaluateJavaScriptCompletionHandler("document.body.height",(val,err)=>{ console.log(val); }); let src = owner.src; if (webView.URL) { src = webView.URL.absoluteString; } owner._onLoadFinished(src); } } public webViewDidFailNavigationWithError(webView: WKWebView, navigation: WKNavigation, error: NSError): void { const owner = this._owner.get(); if (owner) { let src = owner.src; if (webView.URL) { src = webView.URL.absoluteString; } if (traceEnabled()) { traceWrite("WKNavigationDelegateClass.webViewDidFailNavigationWithError(" + error.localizedDescription + ")", traceCategories.Debug); } owner._onLoadFinished(src, error.localizedDescription); } } } export class WebView extends WebViewBase { private _ios: WKWebView; private _delegate: any; constructor() { super(); const configuration = WKWebViewConfiguration.new(); this._delegate = WKNavigationDelegateImpl.initWithOwner(new WeakRef(this)); const jScript = "var meta = document.createElement('meta'); meta.setAttribute('name', 'viewport'); meta.setAttribute('content', 'initial-scale=1.0'); document.getElementsByTagName('head')[0].appendChild(meta);"; const wkUScript = WKUserScript.alloc().initWithSourceInjectionTimeForMainFrameOnly(jScript,WKUserScriptInjectionTime.AtDocumentEnd,true); const wkUController = WKUserContentController.new(); wkUController.addUserScript(wkUScript); configuration.userContentController = wkUController; configuration.preferences.setValueForKey( true, 'allowFileAccessFromFileURLs' ); this.nativeViewProtected = this._ios = new WKWebView({ frame: CGRectZero, configuration:configuration }); } @profile public onLoaded() { super.onLoaded(); this._ios.navigationDelegate = this._delegate; } public onUnloaded() { this._ios.navigationDelegate = null; super.onUnloaded(); } get ios(): WKWebView { return this._ios; } public stopLoading() { this._ios.stopLoading(); } public _loadUrl(src: string) { if(src.startsWith('file:///')){ this._ios.loadFileURLAllowingReadAccessToURL(NSURL.URLWithString(src), NSURL.URLWithString(src)); }else{ this._ios.loadRequest(NSURLRequest.requestWithURL(NSURL.URLWithString(src))); } } public _loadData(content: string) { this._ios.loadHTMLStringBaseURL(content, NSURL.alloc().initWithString(`file:///${knownFolders.currentApp().path}/`)); } get canGoBack(): boolean { return this._ios.canGoBack; } get canGoForward(): boolean { return this._ios.canGoForward; } public goBack() { this._ios.goBack(); } public goForward() { this._ios.goForward(); } public reload() { this._ios.reload(); } }