76 lines
1.8 KiB
Swift
76 lines
1.8 KiB
Swift
|
//
|
||
|
// PreloadedWebView.swift
|
||
|
// Multiplatform iOS
|
||
|
//
|
||
|
// Created by Maurice Parker on 7/6/20.
|
||
|
// Copyright © 2020 Ranchero Software. All rights reserved.
|
||
|
//
|
||
|
|
||
|
import Foundation
|
||
|
import WebKit
|
||
|
|
||
|
class PreloadedWebView: WKWebView {
|
||
|
|
||
|
private var isReady: Bool = false
|
||
|
private var readyCompletion: ((PreloadedWebView) -> Void)?
|
||
|
|
||
|
init(articleIconSchemeHandler: ArticleIconSchemeHandler) {
|
||
|
let preferences = WKPreferences()
|
||
|
preferences.javaScriptCanOpenWindowsAutomatically = false
|
||
|
preferences.javaScriptEnabled = true
|
||
|
|
||
|
let configuration = WKWebViewConfiguration()
|
||
|
configuration.preferences = preferences
|
||
|
configuration.setValue(true, forKey: "allowUniversalAccessFromFileURLs")
|
||
|
configuration.allowsInlineMediaPlayback = true
|
||
|
configuration.mediaTypesRequiringUserActionForPlayback = .audio
|
||
|
configuration.setURLSchemeHandler(articleIconSchemeHandler, forURLScheme: ArticleRenderer.imageIconScheme)
|
||
|
|
||
|
super.init(frame: .zero, configuration: configuration)
|
||
|
}
|
||
|
|
||
|
required init?(coder: NSCoder) {
|
||
|
super.init(coder: coder)
|
||
|
}
|
||
|
|
||
|
func preload() {
|
||
|
navigationDelegate = self
|
||
|
loadFileURL(ArticleRenderer.blank.url, allowingReadAccessTo: ArticleRenderer.blank.baseURL)
|
||
|
}
|
||
|
|
||
|
func ready(completion: @escaping (PreloadedWebView) -> Void) {
|
||
|
if isReady {
|
||
|
completeRequest(completion: completion)
|
||
|
} else {
|
||
|
readyCompletion = completion
|
||
|
}
|
||
|
}
|
||
|
|
||
|
}
|
||
|
|
||
|
// MARK: WKScriptMessageHandler
|
||
|
|
||
|
extension PreloadedWebView: WKNavigationDelegate {
|
||
|
|
||
|
func webView(_ webView: WKWebView, didFinish navigation: WKNavigation!) {
|
||
|
isReady = true
|
||
|
if let completion = readyCompletion {
|
||
|
completeRequest(completion: completion)
|
||
|
readyCompletion = nil
|
||
|
}
|
||
|
}
|
||
|
|
||
|
}
|
||
|
|
||
|
// MARK: Private
|
||
|
|
||
|
private extension PreloadedWebView {
|
||
|
|
||
|
func completeRequest(completion: @escaping (PreloadedWebView) -> Void) {
|
||
|
isReady = false
|
||
|
navigationDelegate = nil
|
||
|
completion(self)
|
||
|
}
|
||
|
|
||
|
}
|