mirror of
https://github.com/Ranchero-Software/NetNewsWire.git
synced 2024-12-20 14:33:04 +01:00
67 lines
1.7 KiB
Swift
67 lines
1.7 KiB
Swift
|
//
|
|||
|
// DetailWebView.swift
|
|||
|
// Evergreen
|
|||
|
//
|
|||
|
// Created by Brent Simmons on 2/10/18.
|
|||
|
// Copyright © 2018 Ranchero Software. All rights reserved.
|
|||
|
//
|
|||
|
|
|||
|
import AppKit
|
|||
|
import WebKit
|
|||
|
|
|||
|
// There’s no API for affecting a WKWebView’s contextual menu.
|
|||
|
// (WebView had API for this.)
|
|||
|
//
|
|||
|
// This a minor hack. It hides unwanted menu items.
|
|||
|
// The menu item identifiers are not documented anywhere;
|
|||
|
// they could change, and this code would need updating.
|
|||
|
|
|||
|
final class DetailWebView: WKWebView {
|
|||
|
|
|||
|
// MARK: NSView
|
|||
|
|
|||
|
override func willOpenMenu(_ menu: NSMenu, with event: NSEvent) {
|
|||
|
|
|||
|
for menuItem in menu.items {
|
|||
|
if shouldHideMenuItem(menuItem) {
|
|||
|
menuItem.isHidden = true
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
super.willOpenMenu(menu, with: event)
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
private extension NSUserInterfaceItemIdentifier {
|
|||
|
|
|||
|
static let DetailMenuItemIdentifierReload = NSUserInterfaceItemIdentifier(rawValue: "WKMenuItemIdentifierReload")
|
|||
|
static let DetailMenuItemIdentifierOpenLink = NSUserInterfaceItemIdentifier(rawValue: "WKMenuItemIdentifierOpenLink")
|
|||
|
}
|
|||
|
|
|||
|
private extension DetailWebView {
|
|||
|
|
|||
|
static let menuItemIdentifiersToHide: [NSUserInterfaceItemIdentifier] = [.DetailMenuItemIdentifierReload, .DetailMenuItemIdentifierOpenLink]
|
|||
|
static let menuItemIdentifierMatchStrings = ["newwindow", "download"]
|
|||
|
|
|||
|
func shouldHideMenuItem(_ menuItem: NSMenuItem) -> Bool {
|
|||
|
|
|||
|
guard let identifier = menuItem.identifier else {
|
|||
|
return false
|
|||
|
}
|
|||
|
|
|||
|
if DetailWebView.menuItemIdentifiersToHide.contains(identifier) {
|
|||
|
return true
|
|||
|
}
|
|||
|
|
|||
|
let lowerIdentifier = identifier.rawValue.lowercased()
|
|||
|
for matchString in DetailWebView.menuItemIdentifierMatchStrings {
|
|||
|
if lowerIdentifier.contains(matchString) {
|
|||
|
return true
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
return false
|
|||
|
}
|
|||
|
}
|
|||
|
|