Refactor how click/hint open targets are handled.

This commit is contained in:
Florian Bruhin 2015-02-26 20:41:04 +01:00
parent fa0bfaa49e
commit a76868c0f4
3 changed files with 46 additions and 37 deletions

View File

@ -110,7 +110,9 @@ class HintManager(QObject):
Signals: Signals:
mouse_event: Mouse event to be posted in the web view. mouse_event: Mouse event to be posted in the web view.
arg: A QMouseEvent arg: A QMouseEvent
set_open_target: Set a new target to open the links in. start_hinting: Emitted when hinting starts, before a link is clicked.
arg: The hinting target name.
stop_hinting: Emitted after a link was clicked.
""" """
HINT_TEXTS = { HINT_TEXTS = {
@ -131,7 +133,8 @@ class HintManager(QObject):
} }
mouse_event = pyqtSignal('QMouseEvent') mouse_event = pyqtSignal('QMouseEvent')
set_open_target = pyqtSignal(str) start_hinting = pyqtSignal(str)
stop_hinting = pyqtSignal()
def __init__(self, win_id, tab_id, parent=None): def __init__(self, win_id, tab_id, parent=None):
"""Constructor.""" """Constructor."""
@ -386,6 +389,7 @@ class HintManager(QObject):
action = "Hovering" if target == Target.hover else "Clicking" action = "Hovering" if target == Target.hover else "Clicking"
log.hints.debug("{} on '{}' at {}/{}".format( log.hints.debug("{} on '{}' at {}/{}".format(
action, elem, pos.x(), pos.y())) action, elem, pos.x(), pos.y()))
self.start_hinting.emit(target.name)
if target in (Target.tab, Target.tab_bg, Target.window): if target in (Target.tab, Target.tab_bg, Target.window):
modifiers = Qt.ControlModifier modifiers = Qt.ControlModifier
else: else:
@ -395,7 +399,6 @@ class HintManager(QObject):
Qt.NoModifier), Qt.NoModifier),
] ]
if target != Target.hover: if target != Target.hover:
self.set_open_target.emit(target.name)
events += [ events += [
QMouseEvent(QEvent.MouseButtonPress, pos, Qt.LeftButton, QMouseEvent(QEvent.MouseButtonPress, pos, Qt.LeftButton,
Qt.LeftButton, modifiers), Qt.LeftButton, modifiers),
@ -408,6 +411,7 @@ class HintManager(QObject):
QTimer.singleShot(0, functools.partial( QTimer.singleShot(0, functools.partial(
elem.webFrame().page().triggerAction, elem.webFrame().page().triggerAction,
QWebPage.MoveToEndOfDocument)) QWebPage.MoveToEndOfDocument))
QTimer.singleShot(0, self.stop_hinting.emit)
def _yank(self, url, context): def _yank(self, url, context):
"""Yank an element to the clipboard or primary selection. """Yank an element to the clipboard or primary selection.

View File

@ -42,6 +42,9 @@ class BrowserPage(QWebPage):
Attributes: Attributes:
error_occured: Whether an error occured while loading. error_occured: Whether an error occured while loading.
open_target: Where to open the next navigation request.
("normal", "tab", "tab_bg")
_hint_target: Override for open_target while hinting, or None.
_extension_handlers: Mapping of QWebPage extensions to their handlers. _extension_handlers: Mapping of QWebPage extensions to their handlers.
_networkmnager: The NetworkManager used. _networkmnager: The NetworkManager used.
_win_id: The window ID this BrowserPage is associated with. _win_id: The window ID this BrowserPage is associated with.
@ -64,6 +67,8 @@ class BrowserPage(QWebPage):
} }
self._ignore_load_started = False self._ignore_load_started = False
self.error_occured = False self.error_occured = False
self.open_target = usertypes.ClickTarget.normal
self._hint_target = None
self._networkmanager = networkmanager.NetworkManager( self._networkmanager = networkmanager.NetworkManager(
win_id, tab_id, self) win_id, tab_id, self)
self.setNetworkAccessManager(self._networkmanager) self.setNetworkAccessManager(self._networkmanager)
@ -405,6 +410,24 @@ class BrowserPage(QWebPage):
if 'scroll-pos' in data and frame.scrollPosition() == QPoint(0, 0): if 'scroll-pos' in data and frame.scrollPosition() == QPoint(0, 0):
frame.setScrollPosition(data['scroll-pos']) frame.setScrollPosition(data['scroll-pos'])
@pyqtSlot(str)
def on_start_hinting(self, hint_target):
"""Emitted before a hinting-click takes place.
Args:
hint_target: A string to set self._hint_target to.
"""
t = getattr(usertypes.ClickTarget, hint_target)
log.webview.debug("Setting force target to {}/{}".format(
hint_target, t))
self._hint_target = t
@pyqtSlot()
def on_stop_hinting(self):
"""Emitted when hinting is finished."""
log.webview.debug("Finishing hinting.")
self._hint_target = None
def userAgentForUrl(self, url): def userAgentForUrl(self, url):
"""Override QWebPage::userAgentForUrl to customize the user agent.""" """Override QWebPage::userAgentForUrl to customize the user agent."""
ua = config.get('network', 'user-agent') ua = config.get('network', 'user-agent')
@ -513,15 +536,17 @@ class BrowserPage(QWebPage):
return False return False
tabbed_browser = objreg.get('tabbed-browser', scope='window', tabbed_browser = objreg.get('tabbed-browser', scope='window',
window=self._win_id) window=self._win_id)
open_target = self.view().open_target if self._hint_target is not None:
self.view().open_target = usertypes.ClickTarget.normal target = self._hint_target
if open_target == usertypes.ClickTarget.tab: else:
target = self.open_target
if target == usertypes.ClickTarget.tab:
tabbed_browser.tabopen(url, False) tabbed_browser.tabopen(url, False)
return False return False
elif open_target == usertypes.ClickTarget.tab_bg: elif target == usertypes.ClickTarget.tab_bg:
tabbed_browser.tabopen(url, True) tabbed_browser.tabopen(url, True)
return False return False
elif open_target == usertypes.ClickTarget.window: elif target == usertypes.ClickTarget.window:
from qutebrowser.mainwindow import mainwindow from qutebrowser.mainwindow import mainwindow
window = mainwindow.MainWindow() window = mainwindow.MainWindow()
window.show() window.show()

View File

@ -55,7 +55,6 @@ class WebView(QWebView):
statusbar_message: The current javscript statusbar message. statusbar_message: The current javscript statusbar message.
inspector: The QWebInspector used for this webview. inspector: The QWebInspector used for this webview.
load_status: loading status of this page (index into LoadStatus) load_status: loading status of this page (index into LoadStatus)
open_target: Where to open the next tab ("normal", "tab", "tab_bg")
viewing_source: Whether the webview is currently displaying source viewing_source: Whether the webview is currently displaying source
code. code.
keep_icon: Whether the (e.g. cloned) icon should not be cleared on page keep_icon: Whether the (e.g. cloned) icon should not be cleared on page
@ -66,7 +65,6 @@ class WebView(QWebView):
_has_ssl_errors: Whether SSL errors occured during loading. _has_ssl_errors: Whether SSL errors occured during loading.
_zoom: A NeighborList with the zoom levels. _zoom: A NeighborList with the zoom levels.
_old_scroll_pos: The old scroll position. _old_scroll_pos: The old scroll position.
_force_open_target: Override for open_target.
_check_insertmode: If True, in mouseReleaseEvent we should check if we _check_insertmode: If True, in mouseReleaseEvent we should check if we
need to enter/leave insert mode. need to enter/leave insert mode.
_default_zoom_changed: Whether the zoom was changed from the default. _default_zoom_changed: Whether the zoom was changed from the default.
@ -101,8 +99,6 @@ class WebView(QWebView):
self.scroll_pos = (-1, -1) self.scroll_pos = (-1, -1)
self.statusbar_message = '' self.statusbar_message = ''
self._old_scroll_pos = (-1, -1) self._old_scroll_pos = (-1, -1)
self.open_target = usertypes.ClickTarget.normal
self._force_open_target = None
self._zoom = None self._zoom = None
self._has_ssl_errors = False self._has_ssl_errors = False
self.keep_icon = False self.keep_icon = False
@ -127,7 +123,8 @@ class WebView(QWebView):
self.setPage(page) self.setPage(page)
hintmanager = hints.HintManager(win_id, self.tab_id, self) hintmanager = hints.HintManager(win_id, self.tab_id, self)
hintmanager.mouse_event.connect(self.on_mouse_event) hintmanager.mouse_event.connect(self.on_mouse_event)
hintmanager.set_open_target.connect(self.set_force_open_target) hintmanager.start_hinting.connect(page.on_start_hinting)
hintmanager.stop_hinting.connect(page.on_stop_hinting)
objreg.register('hintmanager', hintmanager, registry=self.registry) objreg.register('hintmanager', hintmanager, registry=self.registry)
mode_manager = objreg.get('mode-manager', scope='window', mode_manager = objreg.get('mode-manager', scope='window',
window=win_id) window=win_id)
@ -283,24 +280,18 @@ class WebView(QWebView):
Args: Args:
e: The QMouseEvent. e: The QMouseEvent.
""" """
if self._force_open_target is not None: if e.button() == Qt.MidButton or e.modifiers() & Qt.ControlModifier:
self.open_target = self._force_open_target
self._force_open_target = None
log.mouse.debug("Setting force target: {}".format(
self.open_target))
elif (e.button() == Qt.MidButton or
e.modifiers() & Qt.ControlModifier):
background_tabs = config.get('tabs', 'background-tabs') background_tabs = config.get('tabs', 'background-tabs')
if e.modifiers() & Qt.ShiftModifier: if e.modifiers() & Qt.ShiftModifier:
background_tabs = not background_tabs background_tabs = not background_tabs
if background_tabs: if background_tabs:
self.open_target = usertypes.ClickTarget.tab_bg target = usertypes.ClickTarget.tab_bg
else: else:
self.open_target = usertypes.ClickTarget.tab target = usertypes.ClickTarget.tab
log.mouse.debug("Middle click, setting target: {}".format( self.page().open_target = target
self.open_target)) log.mouse.debug("Middle click, setting target: {}".format(target))
else: else:
self.open_target = usertypes.ClickTarget.normal self.page().open_target = usertypes.ClickTarget.normal
log.mouse.debug("Normal click, setting normal target") log.mouse.debug("Normal click, setting normal target")
def shutdown(self): def shutdown(self):
@ -438,17 +429,6 @@ class WebView(QWebView):
"left.".format(mode)) "left.".format(mode))
self.setFocusPolicy(Qt.WheelFocus) self.setFocusPolicy(Qt.WheelFocus)
@pyqtSlot(str)
def set_force_open_target(self, target):
"""Change the forced link target. Setter for _force_open_target.
Args:
target: A string to set self._force_open_target to.
"""
t = getattr(usertypes.ClickTarget, target)
log.webview.debug("Setting force target to {}/{}".format(target, t))
self._force_open_target = t
def createWindow(self, wintype): def createWindow(self, wintype):
"""Called by Qt when a page wants to create a new window. """Called by Qt when a page wants to create a new window.
@ -507,7 +487,7 @@ class WebView(QWebView):
This does the following things: This does the following things:
- Check if a link was clicked with the middle button or Ctrl and - Check if a link was clicked with the middle button or Ctrl and
set the open_target attribute accordingly. set the page's open_target attribute accordingly.
- Emit the editable_elem_selected signal if an editable element was - Emit the editable_elem_selected signal if an editable element was
clicked. clicked.