Support QWebView::createWindow (opening windows via js)
This commit is contained in:
parent
b7eec48037
commit
e2a2ed8850
2
TODO
2
TODO
@ -79,8 +79,6 @@ Bugs
|
|||||||
https://paste.xinu.at/vw6r/
|
https://paste.xinu.at/vw6r/
|
||||||
This seems to happen only with ttf-ms-fonts installed.
|
This seems to happen only with ttf-ms-fonts installed.
|
||||||
|
|
||||||
- Links to articles on https://plus.google.com/+SPIEGELONLINE/posts do not work
|
|
||||||
|
|
||||||
- Hinting problems on https://bugreports.qt-project.org/secure/Dashboard.jspa
|
- Hinting problems on https://bugreports.qt-project.org/secure/Dashboard.jspa
|
||||||
|
|
||||||
Style
|
Style
|
||||||
|
@ -121,7 +121,7 @@ class CurCommandDispatcher(QObject):
|
|||||||
newtab: True to open URL in a new tab, False otherwise.
|
newtab: True to open URL in a new tab, False otherwise.
|
||||||
"""
|
"""
|
||||||
if newtab:
|
if newtab:
|
||||||
self._tabs.tabopen(url)
|
self._tabs.tabopen(url, background=False)
|
||||||
else:
|
else:
|
||||||
self._tabs.currentWidget().openurl(url)
|
self._tabs.currentWidget().openurl(url)
|
||||||
|
|
||||||
|
@ -136,11 +136,10 @@ class TabbedBrowser(TabWidget):
|
|||||||
tab.hintmanager.openurl.connect(self.cur.openurl_slot)
|
tab.hintmanager.openurl.connect(self.cur.openurl_slot)
|
||||||
# misc
|
# misc
|
||||||
tab.titleChanged.connect(self.on_title_changed)
|
tab.titleChanged.connect(self.on_title_changed)
|
||||||
tab.open_tab.connect(self.tabopen)
|
|
||||||
tab.iconChanged.connect(self.on_icon_changed)
|
tab.iconChanged.connect(self.on_icon_changed)
|
||||||
|
|
||||||
@pyqtSlot(str, bool)
|
@pyqtSlot(str, bool)
|
||||||
def tabopen(self, url, background=False):
|
def tabopen(self, url=None, background=None):
|
||||||
"""Open a new tab with a given url.
|
"""Open a new tab with a given url.
|
||||||
|
|
||||||
Inner logic for tabopen and backtabopen.
|
Inner logic for tabopen and backtabopen.
|
||||||
@ -148,18 +147,28 @@ class TabbedBrowser(TabWidget):
|
|||||||
|
|
||||||
Args:
|
Args:
|
||||||
url: The URL to open.
|
url: The URL to open.
|
||||||
background: Whether to oepn the tab in the background.
|
background: Whether to open the tab in the background.
|
||||||
|
if None, the background-tabs setting decides.
|
||||||
|
|
||||||
|
Return:
|
||||||
|
The opened WebView instance.
|
||||||
"""
|
"""
|
||||||
logging.debug("Opening {}".format(url))
|
logging.debug("Creating new tab with url {}".format(url))
|
||||||
url = urlutils.qurl(url)
|
|
||||||
tab = WebView(self)
|
tab = WebView(self)
|
||||||
self._connect_tab_signals(tab)
|
self._connect_tab_signals(tab)
|
||||||
self._tabs.append(tab)
|
self._tabs.append(tab)
|
||||||
|
if url is not None:
|
||||||
|
url = urlutils.qurl(url)
|
||||||
self.addTab(tab, urlutils.urlstring(url))
|
self.addTab(tab, urlutils.urlstring(url))
|
||||||
tab.show()
|
|
||||||
tab.openurl(url)
|
tab.openurl(url)
|
||||||
|
else:
|
||||||
|
self.addTab(tab, "")
|
||||||
|
if background is None:
|
||||||
|
background = config.get('general', 'background-tabs')
|
||||||
if not background:
|
if not background:
|
||||||
self.setCurrentWidget(tab)
|
self.setCurrentWidget(tab)
|
||||||
|
tab.show()
|
||||||
|
return tab
|
||||||
|
|
||||||
def cntwidget(self, count=None):
|
def cntwidget(self, count=None):
|
||||||
"""Return a widget based on a count/idx.
|
"""Return a widget based on a count/idx.
|
||||||
|
@ -49,6 +49,9 @@ class WebView(QWebView):
|
|||||||
page_: The QWebPage behind the view
|
page_: The QWebPage behind the view
|
||||||
signal_cache: The signal cache associated with the view.
|
signal_cache: The signal cache associated with the view.
|
||||||
hintmanager: The HintManager instance for this view.
|
hintmanager: The HintManager instance for this view.
|
||||||
|
tabbedbrowser: The TabbedBrowser this WebView is part of.
|
||||||
|
We need this rather than signals to make createWindow
|
||||||
|
work.
|
||||||
_zoom: A NeighborList with the zoom levels.
|
_zoom: A NeighborList with the zoom levels.
|
||||||
_scroll_pos: The old scroll position.
|
_scroll_pos: The old scroll position.
|
||||||
_shutdown_callback: Callback to be called after shutdown.
|
_shutdown_callback: Callback to be called after shutdown.
|
||||||
@ -61,18 +64,15 @@ class WebView(QWebView):
|
|||||||
scroll_pos_changed: Scroll percentage of current tab changed.
|
scroll_pos_changed: Scroll percentage of current tab changed.
|
||||||
arg 1: x-position in %.
|
arg 1: x-position in %.
|
||||||
arg 2: y-position in %.
|
arg 2: y-position in %.
|
||||||
open_tab: A new tab should be opened.
|
|
||||||
arg 1: The address to open
|
|
||||||
arg 2: Whether to open the tab in the background
|
|
||||||
linkHovered: QWebPages linkHovered signal exposed.
|
linkHovered: QWebPages linkHovered signal exposed.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
scroll_pos_changed = pyqtSignal(int, int)
|
scroll_pos_changed = pyqtSignal(int, int)
|
||||||
open_tab = pyqtSignal('QUrl', bool)
|
|
||||||
linkHovered = pyqtSignal(str, str, str)
|
linkHovered = pyqtSignal(str, str, str)
|
||||||
|
|
||||||
def __init__(self, parent=None):
|
def __init__(self, parent):
|
||||||
super().__init__(parent)
|
super().__init__(parent)
|
||||||
|
self.tabbedbrowser = parent
|
||||||
self._scroll_pos = (-1, -1)
|
self._scroll_pos = (-1, -1)
|
||||||
self._shutdown_callback = None
|
self._shutdown_callback = None
|
||||||
self._open_target = Target.normal
|
self._open_target = Target.normal
|
||||||
@ -219,14 +219,11 @@ class WebView(QWebView):
|
|||||||
|
|
||||||
Args:
|
Args:
|
||||||
url: The url to handle, as string or QUrl.
|
url: The url to handle, as string or QUrl.
|
||||||
|
|
||||||
Emit:
|
|
||||||
open_tab: Emitted if window should be opened in a new tab.
|
|
||||||
"""
|
"""
|
||||||
if self._open_target == Target.tab:
|
if self._open_target == Target.tab:
|
||||||
self.open_tab.emit(url, False)
|
self.tabbedbrowser.tabopen(url, False)
|
||||||
elif self._open_target == Target.bgtab:
|
elif self._open_target == Target.bgtab:
|
||||||
self.open_tab.emit(url, True)
|
self.tabbedbrowser.tabopen(url, True)
|
||||||
else:
|
else:
|
||||||
self.openurl(url)
|
self.openurl(url)
|
||||||
|
|
||||||
@ -267,6 +264,30 @@ class WebView(QWebView):
|
|||||||
logging.debug("Setting force target to {}/{}".format(target, t))
|
logging.debug("Setting force target to {}/{}".format(target, t))
|
||||||
self._force_open_target = t
|
self._force_open_target = t
|
||||||
|
|
||||||
|
def createWindow(self, wintype):
|
||||||
|
"""Called by Qt when a page wants to create a new window.
|
||||||
|
|
||||||
|
This function is called from the createWindow() method of the
|
||||||
|
associated QWebPage, each time the page wants to create a new window of
|
||||||
|
the given type. This might be the result, for example, of a JavaScript
|
||||||
|
request to open a document in a new window.
|
||||||
|
|
||||||
|
Args:
|
||||||
|
wintype: This enum describes the types of window that can be
|
||||||
|
created by the createWindow() function.
|
||||||
|
|
||||||
|
QWebPage::WebBrowserWindow: The window is a regular web
|
||||||
|
browser window.
|
||||||
|
QWebPage::WebModalDialog: The window acts as modal dialog.
|
||||||
|
|
||||||
|
Return:
|
||||||
|
The new QWebView object.
|
||||||
|
"""
|
||||||
|
if wintype == QWebPage.WebModalDialog:
|
||||||
|
logging.warn("WebModalDialog requested, but we don't support "
|
||||||
|
"that!")
|
||||||
|
return self.tabbedbrowser.tabopen()
|
||||||
|
|
||||||
def paintEvent(self, e):
|
def paintEvent(self, e):
|
||||||
"""Extend paintEvent to emit a signal if the scroll position changed.
|
"""Extend paintEvent to emit a signal if the scroll position changed.
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user