mirror of
https://github.com/NativeScript/NativeScript.git
synced 2025-08-15 02:54:11 +08:00

* chore: move tns-core-modules to nativescript-core * chore: preparing compat generate script * chore: add missing definitions * chore: no need for http-request to be private * chore: packages chore * test: generate tests for tns-core-modules * chore: add anroid module for consistency * chore: add .npmignore * chore: added privateModulesWhitelist * chore(webpack): added bundle-entry-points * chore: scripts * chore: tests changed to use @ns/core * test: add scoped-packages test project * test: fix types * test: update test project * chore: build scripts * chore: update build script * chore: npm scripts cleanup * chore: make the compat pgk work with old wp config * test: generate diff friendly tests * chore: create barrel exports * chore: move files after rebase * chore: typedoc config * chore: compat mode * chore: review of barrels * chore: remove tns-core-modules import after rebase * chore: dev workflow setup * chore: update developer-workflow * docs: experiment with API extractor * chore: api-extractor and barrel exports * chore: api-extractor configs * chore: generate d.ts rollup with api-extractor * refactor: move methods inside Frame * chore: fic tests to use Frame static methods * refactor: create Builder class * refactor: use Builder class in tests * refactor: include Style in ui barrel * chore: separate compat build script * chore: fix tslint errors * chore: update NATIVESCRIPT_CORE_ARGS * chore: fix compat pack * chore: fix ui-test-app build with linked modules * chore: Application, ApplicationSettings, Connectivity and Http * chore: export Trace, Profiling and Utils * refactor: Static create methods for ImageSource * chore: fix deprecated usages of ImageSource * chore: move Span and FormattedString to ui * chore: add events-args and ImageSource to index files * chore: check for CLI >= 6.2 when building for IOS * chore: update travis build * chore: copy Pod file to compat package * chore: update error msg ui-tests-app * refactor: Apply suggestions from code review Co-Authored-By: Martin Yankov <m.i.yankov@gmail.com> * chore: typings and refs * chore: add missing d.ts files for public API * chore: adress code review FB * chore: update api-report * chore: dev-workflow for other apps * chore: api update * chore: update api-report
181 lines
6.4 KiB
TypeScript
181 lines
6.4 KiB
TypeScript
import { WebViewBase, knownFolders, traceWrite, traceEnabled, traceCategories, NavigationType } from "./web-view-common";
|
|
import { profile } from "../../profiling";
|
|
export * from "./web-view-common";
|
|
|
|
class WKNavigationDelegateImpl extends NSObject
|
|
implements WKNavigationDelegate {
|
|
public static ObjCProtocols = [WKNavigationDelegate];
|
|
public static initWithOwner(owner: WeakRef<WebView>): WKNavigationDelegateImpl {
|
|
const handler = <WKNavigationDelegateImpl>WKNavigationDelegateImpl.new();
|
|
handler._owner = owner;
|
|
|
|
return handler;
|
|
}
|
|
private _owner: WeakRef<WebView>;
|
|
|
|
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) {
|
|
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);
|
|
}
|
|
}
|
|
|
|
public webViewDidFailProvisionalNavigationWithError(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.webViewDidFailProvisionalNavigationWithError(" + error.localizedDescription + ")", traceCategories.Debug);
|
|
}
|
|
owner._onLoadFinished(src, error.localizedDescription);
|
|
}
|
|
}
|
|
|
|
}
|
|
|
|
export class WebView extends WebViewBase {
|
|
nativeViewProtected: WKWebView;
|
|
private _delegate: any;
|
|
|
|
createNativeView() {
|
|
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);
|
|
const configuration = WKWebViewConfiguration.new();
|
|
configuration.userContentController = wkUController;
|
|
configuration.preferences.setValueForKey(
|
|
true,
|
|
"allowFileAccessFromFileURLs"
|
|
);
|
|
|
|
return new WKWebView({
|
|
frame: CGRectZero,
|
|
configuration: configuration
|
|
});
|
|
}
|
|
|
|
initNativeView() {
|
|
super.initNativeView();
|
|
this._delegate = WKNavigationDelegateImpl.initWithOwner(new WeakRef(this));
|
|
}
|
|
|
|
disposeNativeView() {
|
|
this._delegate = null;
|
|
super.disposeNativeView();
|
|
}
|
|
|
|
@profile
|
|
public onLoaded() {
|
|
super.onLoaded();
|
|
this.ios.navigationDelegate = this._delegate;
|
|
}
|
|
|
|
public onUnloaded() {
|
|
this.ios.navigationDelegate = null;
|
|
super.onUnloaded();
|
|
}
|
|
|
|
get ios(): WKWebView {
|
|
return this.nativeViewProtected;
|
|
}
|
|
|
|
public stopLoading() {
|
|
this.ios.stopLoading();
|
|
}
|
|
|
|
public _loadUrl(src: string) {
|
|
if (src.startsWith("file:///")) {
|
|
const cachePath = src.substring(0, src.lastIndexOf("/"));
|
|
this.ios.loadFileURLAllowingReadAccessToURL(NSURL.URLWithString(src), NSURL.URLWithString(cachePath));
|
|
} 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();
|
|
}
|
|
}
|