Merge pull request #24 from huzhiren/master
Fixed error: Double value cannot be converted to Int because the result would be greater than Int.max in 32-bit devices
This commit is contained in:
commit
a2b7e48221
|
@ -64,10 +64,10 @@ window.\(JAVASCRIPT_BRIDGE_NAME).callHandler = function(handlerName, ...args) {
|
||||||
}
|
}
|
||||||
"""
|
"""
|
||||||
|
|
||||||
func currentTimeInMilliSeconds() -> Int {
|
func currentTimeInMilliSeconds() -> Int64 {
|
||||||
let currentDate = Date()
|
let currentDate = Date()
|
||||||
let since1970 = currentDate.timeIntervalSince1970
|
let since1970 = currentDate.timeIntervalSince1970
|
||||||
return Int(since1970 * 1000)
|
return Int64(since1970 * 1000)
|
||||||
}
|
}
|
||||||
|
|
||||||
func convertToDictionary(text: String) -> [String: Any]? {
|
func convertToDictionary(text: String) -> [String: Any]? {
|
||||||
|
@ -168,7 +168,7 @@ class InAppBrowserWebViewController: UIViewController, UIScrollViewDelegate, WKU
|
||||||
var isHidden = false
|
var isHidden = false
|
||||||
var uuid: String = ""
|
var uuid: String = ""
|
||||||
var WKNavigationMap: [String: [String: Any]] = [:]
|
var WKNavigationMap: [String: [String: Any]] = [:]
|
||||||
var startPageTime = 0
|
var startPageTime: Int64 = 0
|
||||||
var viewPrepared = false
|
var viewPrepared = false
|
||||||
|
|
||||||
required init(coder aDecoder: NSCoder) {
|
required init(coder aDecoder: NSCoder) {
|
||||||
|
@ -609,9 +609,9 @@ class InAppBrowserWebViewController: UIViewController, UIScrollViewDelegate, WKU
|
||||||
if (webViewOptions?.useOnLoadResource)! {
|
if (webViewOptions?.useOnLoadResource)! {
|
||||||
if let url = navigationResponse.response.url {
|
if let url = navigationResponse.response.url {
|
||||||
if WKNavigationMap[url.absoluteString] != nil {
|
if WKNavigationMap[url.absoluteString] != nil {
|
||||||
let startResourceTime = (WKNavigationMap[url.absoluteString]!["startTime"] as! Int)
|
let startResourceTime: Int64 = (WKNavigationMap[url.absoluteString]!["startTime"] as! Int64)
|
||||||
let startTime = startResourceTime - startPageTime;
|
let startTime: Int64 = startResourceTime - startPageTime;
|
||||||
let duration = currentTimeInMilliSeconds() - startResourceTime;
|
let duration: Int64 = currentTimeInMilliSeconds() - startResourceTime;
|
||||||
self.didReceiveResourceResponse(navigationResponse.response, fromRequest: WKNavigationMap[url.absoluteString]!["request"] as? URLRequest, withData: Data(), startTime: startTime, duration: duration)
|
self.didReceiveResourceResponse(navigationResponse.response, fromRequest: WKNavigationMap[url.absoluteString]!["request"] as? URLRequest, withData: Data(), startTime: startTime, duration: duration)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -701,7 +701,7 @@ class InAppBrowserWebViewController: UIViewController, UIScrollViewDelegate, WKU
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func didReceiveResourceResponse(_ response: URLResponse, fromRequest request: URLRequest?, withData data: Data, startTime: Int, duration: Int) {
|
func didReceiveResourceResponse(_ response: URLResponse, fromRequest request: URLRequest?, withData data: Data, startTime: Int64, duration: Int64) {
|
||||||
if navigationDelegate != nil {
|
if navigationDelegate != nil {
|
||||||
navigationDelegate?.onLoadResource(uuid: self.uuid, webView: webView, response: response, fromRequest: request, withData: data, startTime: startTime, duration: duration)
|
navigationDelegate?.onLoadResource(uuid: self.uuid, webView: webView, response: response, fromRequest: request, withData: data, startTime: startTime, duration: duration)
|
||||||
}
|
}
|
||||||
|
@ -750,8 +750,8 @@ class InAppBrowserWebViewController: UIViewController, UIScrollViewDelegate, WKU
|
||||||
if !UIApplication.shared.canOpenURL(url) {
|
if !UIApplication.shared.canOpenURL(url) {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
let startTime = Int(resource["startTime"] as! Double)
|
let startTime = Int64(resource["startTime"] as! Double)
|
||||||
let duration = Int(resource["duration"] as! Double)
|
let duration = Int64(resource["duration"] as! Double)
|
||||||
var urlRequest = URLRequest(url: url)
|
var urlRequest = URLRequest(url: url)
|
||||||
urlRequest.allHTTPHeaderFields = [:]
|
urlRequest.allHTTPHeaderFields = [:]
|
||||||
let config = URLSessionConfiguration.default
|
let config = URLSessionConfiguration.default
|
||||||
|
|
|
@ -15,7 +15,7 @@ public class InAppWebView: WKWebView, UIScrollViewDelegate, WKUIDelegate, WKNavi
|
||||||
var options: InAppWebViewOptions?
|
var options: InAppWebViewOptions?
|
||||||
var currentURL: URL?
|
var currentURL: URL?
|
||||||
var WKNavigationMap: [String: [String: Any]] = [:]
|
var WKNavigationMap: [String: [String: Any]] = [:]
|
||||||
var startPageTime = 0
|
var startPageTime: Int64 = 0
|
||||||
|
|
||||||
init(frame: CGRect, configuration: WKWebViewConfiguration, IABController: InAppBrowserWebViewController?, IAWController: FlutterWebViewController?) {
|
init(frame: CGRect, configuration: WKWebViewConfiguration, IABController: InAppBrowserWebViewController?, IAWController: FlutterWebViewController?) {
|
||||||
super.init(frame: frame, configuration: configuration)
|
super.init(frame: frame, configuration: configuration)
|
||||||
|
@ -449,9 +449,9 @@ public class InAppWebView: WKWebView, UIScrollViewDelegate, WKUIDelegate, WKNavi
|
||||||
if (options?.useOnLoadResource)! {
|
if (options?.useOnLoadResource)! {
|
||||||
if let url = navigationResponse.response.url {
|
if let url = navigationResponse.response.url {
|
||||||
if WKNavigationMap[url.absoluteString] != nil {
|
if WKNavigationMap[url.absoluteString] != nil {
|
||||||
let startResourceTime = (WKNavigationMap[url.absoluteString]!["startTime"] as! Int)
|
let startResourceTime: Int64 = (WKNavigationMap[url.absoluteString]!["startTime"] as! Int64)
|
||||||
let startTime = startResourceTime - startPageTime;
|
let startTime: Int64 = startResourceTime - startPageTime;
|
||||||
let duration = currentTimeInMilliSeconds() - startResourceTime;
|
let duration: Int64 = currentTimeInMilliSeconds() - startResourceTime;
|
||||||
onLoadResource(response: navigationResponse.response, fromRequest: WKNavigationMap[url.absoluteString]!["request"] as? URLRequest, withData: Data(), startTime: startTime, duration: duration)
|
onLoadResource(response: navigationResponse.response, fromRequest: WKNavigationMap[url.absoluteString]!["request"] as? URLRequest, withData: Data(), startTime: startTime, duration: duration)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -520,7 +520,7 @@ public class InAppWebView: WKWebView, UIScrollViewDelegate, WKUIDelegate, WKNavi
|
||||||
getChannel().invokeMethod("onProgressChanged", arguments: arguments)
|
getChannel().invokeMethod("onProgressChanged", arguments: arguments)
|
||||||
}
|
}
|
||||||
|
|
||||||
public func onLoadResource(response: URLResponse, fromRequest request: URLRequest?, withData data: Data, startTime: Int, duration: Int) {
|
public func onLoadResource(response: URLResponse, fromRequest request: URLRequest?, withData data: Data, startTime: Int64, duration: Int64) {
|
||||||
var headersResponse = (response as! HTTPURLResponse).allHeaderFields as! [String: String]
|
var headersResponse = (response as! HTTPURLResponse).allHeaderFields as! [String: String]
|
||||||
headersResponse.lowercaseKeys()
|
headersResponse.lowercaseKeys()
|
||||||
|
|
||||||
|
@ -613,8 +613,8 @@ public class InAppWebView: WKWebView, UIScrollViewDelegate, WKUIDelegate, WKNavi
|
||||||
if !UIApplication.shared.canOpenURL(url) {
|
if !UIApplication.shared.canOpenURL(url) {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
let startTime = Int(resource["startTime"] as! Double)
|
let startTime: Int64 = Int64(resource["startTime"] as! Double)
|
||||||
let duration = Int(resource["duration"] as! Double)
|
let duration: Int64 = Int64(resource["duration"] as! Double)
|
||||||
var urlRequest = URLRequest(url: url)
|
var urlRequest = URLRequest(url: url)
|
||||||
urlRequest.allHTTPHeaderFields = [:]
|
urlRequest.allHTTPHeaderFields = [:]
|
||||||
let config = URLSessionConfiguration.default
|
let config = URLSessionConfiguration.default
|
||||||
|
|
|
@ -734,7 +734,7 @@ public class SwiftFlutterPlugin: NSObject, FlutterPlugin {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func onLoadResource(uuid: String, webView: WKWebView, response: URLResponse, fromRequest request: URLRequest?, withData data: Data, startTime: Int, duration: Int) {
|
func onLoadResource(uuid: String, webView: WKWebView, response: URLResponse, fromRequest request: URLRequest?, withData data: Data, startTime: Int64, duration: Int64) {
|
||||||
if self.webViewControllers[uuid] != nil {
|
if self.webViewControllers[uuid] != nil {
|
||||||
var headersResponse = (response as! HTTPURLResponse).allHeaderFields as! [String: String]
|
var headersResponse = (response as! HTTPURLResponse).allHeaderFields as! [String: String]
|
||||||
headersResponse.lowercaseKeys()
|
headersResponse.lowercaseKeys()
|
||||||
|
|
Loading…
Reference in New Issue