diff options
author | Aqua-sama <aqua@iserlohn-fortress.net> | 2017-06-11 16:00:31 +0200 |
---|---|---|
committer | Aqua-sama <aqua@iserlohn-fortress.net> | 2017-06-11 16:00:31 +0200 |
commit | 765f33e796dbc1e8c5fefd77c9cf4cdf58a99a83 (patch) | |
tree | 48dfd56b366d96d4bb06b8cda4ba2776622815cc /src/widgets | |
parent | Added new profile button (diff) | |
download | smolbote-765f33e796dbc1e8c5fefd77c9cf4cdf58a99a83.tar.xz |
Fixed crash when closing last tab
Diffstat (limited to 'src/widgets')
-rw-r--r-- | src/widgets/webviewtabbar.cpp | 30 | ||||
-rw-r--r-- | src/widgets/webviewtabbar.h | 6 |
2 files changed, 30 insertions, 6 deletions
diff --git a/src/widgets/webviewtabbar.cpp b/src/widgets/webviewtabbar.cpp index 429b103..d57e095 100644 --- a/src/widgets/webviewtabbar.cpp +++ b/src/widgets/webviewtabbar.cpp @@ -22,12 +22,15 @@ #include "browser.h" #include <QAction> -WebViewTabBar::WebViewTabBar(QWidget *parent) : +WebViewTabBar::WebViewTabBar(QWebEngineProfile *profile, QWidget *parent) : QTabBar(parent) { + m_profile = profile; + setElideMode(Qt::ElideRight); setTabsClosable(true); setMovable(true); + setContextMenuPolicy(Qt::DefaultContextMenu); connect(this, SIGNAL(tabCloseRequested(int)), this, SLOT(removeTab(int))); connect(this, SIGNAL(currentChanged(int)), this, SLOT(handleCurrentChanged(int))); connect(this, SIGNAL(tabMoved(int,int)), this, SLOT(updateVectorArrangement(int,int))); @@ -73,15 +76,14 @@ QSignalMapper *WebViewTabBar::signalMapper() return m_signalMapper; } -int WebViewTabBar::addTab(QWebEngineProfile *profile, const QUrl &url) +int WebViewTabBar::addTab(const QUrl &url) { WebView *view = new WebView(0); - QWebEnginePage *page = new QWebEnginePage(profile); + QWebEnginePage *page = new QWebEnginePage(m_profile); view->setPage(page); page->load(url); m_views.append(view); - //connect(view, SIGNAL(titleChanged()), this, SLOT(updateTabText())); connect(view, &QWebEngineView::titleChanged, [this, view](const QString &title) { int index = m_views.indexOf(view); setTabText(index, title); @@ -96,6 +98,7 @@ int WebViewTabBar::addTab(QWebEngineProfile *profile, const QUrl &url) void WebViewTabBar::setProfile(QWebEngineProfile *profile) { + m_profile = profile; for(auto view : qAsConst(m_views)) { QWebEnginePage *page = new QWebEnginePage(profile); page->load(view->url()); @@ -108,6 +111,21 @@ WebView *WebViewTabBar::currentView() return m_views.at(currentIndex()); } +void WebViewTabBar::contextMenuEvent(QContextMenuEvent *event) +{ + int tabIndex = tabAt(event->pos()); + if(tabIndex < 0) { + return; + } + + QMenu menu(this); + QAction* closeAction = menu.addAction(tr("Close tab")); + connect(closeAction, &QAction::triggered, this, [tabIndex, this]() { + removeTab(tabIndex); + }); + menu.exec(event->globalPos()); +} + QSize WebViewTabBar::tabSizeHint(int index) const { Q_UNUSED(index) @@ -116,6 +134,10 @@ QSize WebViewTabBar::tabSizeHint(int index) const void WebViewTabBar::handleCurrentChanged(int index) { + if(index < 0) { + addTab(QUrl::fromUserInput(sSettings->value("general.newtab").toString())); + return; + } emit currentTabChanged(m_views.at(index)); } diff --git a/src/widgets/webviewtabbar.h b/src/widgets/webviewtabbar.h index bf39efe..d1ccf81 100644 --- a/src/widgets/webviewtabbar.h +++ b/src/widgets/webviewtabbar.h @@ -30,7 +30,7 @@ class WebViewTabBar : public QTabBar Q_OBJECT public: - explicit WebViewTabBar(QWidget *parent = 0); + explicit WebViewTabBar(QWebEngineProfile *profile, QWidget *parent = 0); ~WebViewTabBar(); void setProfile(QWebEngineProfile *profile); @@ -42,12 +42,13 @@ signals: void currentTabChanged(WebView *view); public slots: - int addTab(QWebEngineProfile *profile, const QUrl &url); + int addTab(const QUrl &url); void removeTab(int index); void webAction(int action); protected: + void contextMenuEvent(QContextMenuEvent *event); QSize tabSizeHint(int index) const; private slots: @@ -61,6 +62,7 @@ private: QVector<WebView*> m_views; QSignalMapper *m_signalMapper; + QWebEngineProfile *m_profile; }; #endif // WEBVIEWTABBAR_H |