Configurable behavior of close mouse button on bar

This commit is contained in:
Aneesh Roy 2017-10-16 15:44:52 +01:00
parent e89fda189a
commit 674269724f
3 changed files with 32 additions and 1 deletions

View File

@ -1127,6 +1127,16 @@ tabs.close_mouse_button:
- none: "Don't close tabs using the mouse." - none: "Don't close tabs using the mouse."
desc: On which mouse button to close tabs. desc: On which mouse button to close tabs.
tabs.close_mouse_button_on_bar:
default: new-tab
type:
name: String
valid_values:
- new-tab: "Open a new tab."
- close-current: "Close the current tab."
- close-last: "Close the last tab."
desc: Behavior when the close mouse button is pressed on the tab bar.
tabs.favicons.scale: tabs.favicons.scale:
default: 1.0 default: 1.0
type: type:

View File

@ -116,6 +116,7 @@ class TabbedBrowser(tabwidget.TabWidget):
self._tab_insert_idx_right = -1 self._tab_insert_idx_right = -1
self.shutting_down = False self.shutting_down = False
self.tabCloseRequested.connect(self.on_tab_close_requested) self.tabCloseRequested.connect(self.on_tab_close_requested)
self.new_tab_requested.connect(self.openurl)
self.currentChanged.connect(self.on_current_changed) self.currentChanged.connect(self.on_current_changed)
self.cur_load_started.connect(self.on_cur_load_started) self.cur_load_started.connect(self.on_cur_load_started)
self.cur_fullscreen_requested.connect(self.tabBar().maybe_hide) self.cur_fullscreen_requested.connect(self.tabBar().maybe_hide)

View File

@ -46,9 +46,11 @@ class TabWidget(QTabWidget):
tab_index_changed: Emitted when the current tab was changed. tab_index_changed: Emitted when the current tab was changed.
arg 0: The index of the tab which is now focused. arg 0: The index of the tab which is now focused.
arg 1: The total count of tabs. arg 1: The total count of tabs.
new_tab_requested: Emitted when a new tab is requested.
""" """
tab_index_changed = pyqtSignal(int, int) tab_index_changed = pyqtSignal(int, int)
new_tab_requested = pyqtSignal('QUrl', bool)
def __init__(self, win_id, parent=None): def __init__(self, win_id, parent=None):
super().__init__(parent) super().__init__(parent)
@ -59,6 +61,7 @@ class TabWidget(QTabWidget):
bar.tabMoved.connect(functools.partial( bar.tabMoved.connect(functools.partial(
QTimer.singleShot, 0, self._update_tab_titles)) QTimer.singleShot, 0, self._update_tab_titles))
bar.currentChanged.connect(self._on_current_changed) bar.currentChanged.connect(self._on_current_changed)
bar.new_tab_requested.connect(self._on_new_tab_requested)
self.setSizePolicy(QSizePolicy.Expanding, QSizePolicy.Fixed) self.setSizePolicy(QSizePolicy.Expanding, QSizePolicy.Fixed)
self.setDocumentMode(True) self.setDocumentMode(True)
self.setElideMode(Qt.ElideRight) self.setElideMode(Qt.ElideRight)
@ -261,6 +264,11 @@ class TabWidget(QTabWidget):
self.tabBar().on_current_changed() self.tabBar().on_current_changed()
self.tab_index_changed.emit(index, self.count()) self.tab_index_changed.emit(index, self.count())
@pyqtSlot()
def _on_new_tab_requested(self):
"""Open a new tab."""
self.new_tab_requested.emit(config.val.url.default_page, True)
def tab_url(self, idx): def tab_url(self, idx):
"""Get the URL of the tab at the given index. """Get the URL of the tab at the given index.
@ -290,8 +298,13 @@ class TabBar(QTabBar):
Attributes: Attributes:
vertical: When the tab bar is currently vertical. vertical: When the tab bar is currently vertical.
win_id: The window ID this TabBar belongs to. win_id: The window ID this TabBar belongs to.
Signals:
new_tab_requested: Emitted when a new tab is requested.
""" """
new_tab_requested = pyqtSignal()
def __init__(self, win_id, parent=None): def __init__(self, win_id, parent=None):
super().__init__(parent) super().__init__(parent)
self._win_id = win_id self._win_id = win_id
@ -424,7 +437,14 @@ class TabBar(QTabBar):
e.accept() e.accept()
idx = self.tabAt(e.pos()) idx = self.tabAt(e.pos())
if idx == -1: if idx == -1:
idx = self.currentIndex() action = config.val.tabs.close_mouse_button_on_bar
if action == 'new-tab':
self.new_tab_requested.emit()
return
elif action == 'close-current':
idx = self.currentIndex()
elif action == 'close-last':
idx = self.count() - 1
self.tabCloseRequested.emit(idx) self.tabCloseRequested.emit(idx)
return return
super().mousePressEvent(e) super().mousePressEvent(e)