aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--lib/configuration/configuration.cpp1
-rw-r--r--src/mainwindow/menubar.cpp40
2 files changed, 18 insertions, 23 deletions
diff --git a/lib/configuration/configuration.cpp b/lib/configuration/configuration.cpp
index d4f1eae..9a1c3b8 100644
--- a/lib/configuration/configuration.cpp
+++ b/lib/configuration/configuration.cpp
@@ -87,6 +87,7 @@ Configuration::Configuration(int argc, char **argv, const std::string &path, QOb
("subwindow.shortcuts.menu", po::value<std::string>()->default_value(CONFIG_SHORTCUT_SUBWINDOW_MENU))
("subwindow.shortcuts.new", po::value<std::string>()->default_value(CONFIG_SHORTCUT_SUBWINDOW_NEWTAB))
("subwindow.shortcuts.close", po::value<std::string>()->default_value(CONFIG_SHORTCUT_SUBWINDOW_CLOSETAB))
+ ("subwindow.shortcuts.restoreTab", po::value<std::string>()->default_value("Ctrl+Shift+T"))
("subwindow.shortcuts.left", po::value<std::string>()->default_value(CONFIG_SHORTCUT_SUBWINDOW_TABLEFT))
("subwindow.shortcuts.moveLeft", po::value<std::string>()->default_value(CONFIG_SHORTCUT_SUBWINDOW_MOVETABLEFT))
("subwindow.shortcuts.right", po::value<std::string>()->default_value(CONFIG_SHORTCUT_SUBWINDOW_TABRIGHT))
diff --git a/src/mainwindow/menubar.cpp b/src/mainwindow/menubar.cpp
index bdfbd23..bc06f65 100644
--- a/src/mainwindow/menubar.cpp
+++ b/src/mainwindow/menubar.cpp
@@ -144,23 +144,22 @@ MenuBar::MenuBar(const Configuration *config, MainWindow *parent)
auto *subwindow = this->addMenu(tr("Subwindow"));
{
auto *actionNewTab = subwindow->addAction(tr("New Tab"), parent, [parent]() {
- auto *_subwindow = parent->currentSubWindow();
- if(_subwindow != nullptr) {
+ run_if(parent->currentSubWindow(), [](SubWindow *_subwindow, int) {
const int index = _subwindow->addTab();
_subwindow->setCurrentTab(index);
- }
+ });
});
config->setShortcut(actionNewTab, "subwindow.shortcuts.new");
subwindow->addSeparator();
- subwindow->addAction(tr("Restore last tab"), parent, [parent]() {
- auto *_subwindow = parent->currentSubWindow();
- if(_subwindow != nullptr) {
+ auto *actionRestoreTab = subwindow->addAction(tr("Restore last tab"), parent, [parent]() {
+ run_if(parent->currentSubWindow(), [](SubWindow *_subwindow, int) {
const int index = _subwindow->restoreLastTab();
_subwindow->setCurrentTab(index);
- }
+ });
});
+ config->setShortcut(actionRestoreTab, "subwindow.shortcuts.restoreTab");
auto *restoreTabsMenu = subwindow->addMenu(tr("Restore previous tab"));
connect(restoreTabsMenu, &QMenu::aboutToShow, parent, [parent, restoreTabsMenu]() {
@@ -178,34 +177,29 @@ MenuBar::MenuBar(const Configuration *config, MainWindow *parent)
actionPinTab->setEnabled(false);
auto *actionLockClose = subwindow->addAction(tr("Prevent tab from closing"), parent, [parent](bool checked) {
- auto *_subwindow = parent->currentSubWindow();
- if(_subwindow != nullptr) {
- const int idx = _subwindow->currentTabIndex();
- auto data = _subwindow->tabData(idx);
+ run_if(parent->currentSubWindow(), [checked](SubWindow *_subwindow, int currentIdx) {
+ auto data = _subwindow->tabData(currentIdx);
data.closeLocked = checked;
- _subwindow->setTabData(data, idx);
- }
+ _subwindow->setTabData(data, currentIdx);
+ });
});
actionLockClose->setCheckable(true);
auto *actionLockRefresh = subwindow->addAction(tr("Prevent tab from refreshing"), parent, [parent](bool checked) {
- auto *_subwindow = parent->currentSubWindow();
- if(_subwindow != nullptr) {
- const int idx = _subwindow->currentTabIndex();
- auto data = _subwindow->tabData(idx);
+ run_if(parent->currentSubWindow(), [checked](SubWindow *_subwindow, int currentIdx) {
+ auto data = _subwindow->tabData(currentIdx);
data.refreshLocked = checked;
- _subwindow->setTabData(data, idx);
- }
+ _subwindow->setTabData(data, currentIdx);
+ });
});
actionLockRefresh->setCheckable(true);
connect(subwindow, &QMenu::aboutToShow, subwindow, [=]() {
- auto *_subwindow = parent->currentSubWindow();
- if(_subwindow != nullptr) {
- auto data = _subwindow->tabData(_subwindow->currentTabIndex());
+ run_if(parent->currentSubWindow(), [=](SubWindow *_subwindow, int currentIdx) {
+ auto data = _subwindow->tabData(currentIdx);
actionLockClose->setChecked(data.closeLocked);
actionLockRefresh->setChecked(data.refreshLocked);
- }
+ });
});
subwindow->addSeparator()->setText(tr("Tab Actions"));