/* * Copyright (C) 2014, 2015 Nicolas Bonnefon and other contributors * * This file is part of glogg. * * glogg is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * glogg is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with glogg. If not, see . */ #include "tabbedcrawlerwidget.h" #include #include #include "crawlerwidget.h" #include "log.h" TabbedCrawlerWidget::TabbedCrawlerWidget() : QTabWidget(), olddata_icon_( ":/images/olddata_icon.png" ), newdata_icon_( ":/images/newdata_icon.png" ), newfiltered_icon_( ":/images/newfiltered_icon.png" ), myTabBar_() { #ifdef WIN32 myTabBar_.setStyleSheet( "QTabBar::tab {\ height: 20px; " "} " "QTabBar::close-button {\ height: 6px; width: 6px;\ subcontrol-origin: padding;\ subcontrol-position: left;\ }" ); #else // On GTK style, it looks better with a smaller font myTabBar_.setStyleSheet( "QTabBar::tab {" " height: 20px; " " font-size: 9pt; " "} " "QTabBar::close-button {\ height: 6px; width: 6px;\ subcontrol-origin: padding;\ subcontrol-position: left;\ }" ); #endif setTabBar( &myTabBar_ ); myTabBar_.hide(); } // I know hiding non-virtual functions from the base class is bad form // and I do it here out of pure laziness: I don't want to encapsulate // QTabBar with all signals and all just to implement this very simple logic. // Maybe one day that should be done better... int TabbedCrawlerWidget::addTab( QWidget* page, const QString& label ) { int index = QTabWidget::addTab( page, label ); if ( auto crawler = dynamic_cast( page ) ) { // Mmmmhhhh... new Qt5 signal syntax create tight coupling between // us and the sender, baaaaad.... // Listen for a changing data status: connect( crawler, &CrawlerWidget::dataStatusChanged, [ this, index ]( DataStatus status ) { setTabDataStatus( index, status ); } ); } // Display the icon QLabel* icon_label = new QLabel(); icon_label->setPixmap( olddata_icon_.pixmap( 11, 12 ) ); icon_label->setAlignment( Qt::AlignCenter ); myTabBar_.setTabButton( index, QTabBar::RightSide, icon_label ); LOG(logDEBUG) << "addTab, count = " << count(); LOG(logDEBUG) << "width = " << olddata_icon_.pixmap( 11, 12 ).devicePixelRatio(); if ( count() > 1 ) myTabBar_.show(); return index; } void TabbedCrawlerWidget::removeTab( int index ) { QTabWidget::removeTab( index ); if ( count() <= 1 ) myTabBar_.hide(); } void TabbedCrawlerWidget::mouseReleaseEvent( QMouseEvent *event) { LOG(logDEBUG) << "TabbedCrawlerWidget::mouseReleaseEvent"; if (event->button() == Qt::MidButton) { int tab = this->myTabBar_.tabAt( event->pos() ); if (-1 != tab) { emit tabCloseRequested( tab ); } } } void TabbedCrawlerWidget::keyPressEvent( QKeyEvent* event ) { LOG(logDEBUG) << "TabbedCrawlerWidget::keyPressEvent"; char c = ( event->text() )[0].toLatin1(); Qt::KeyboardModifiers mod = event->modifiers(); // Ctrl + tab if ( mod == Qt::ControlModifier && c == '\t' ) { setCurrentIndex( ( currentIndex() + 1 ) % count() ); } // Ctrl + shift + tab else if ( mod == ( Qt::ControlModifier | Qt::ShiftModifier ) && c == '\t' ) { setCurrentIndex( ( currentIndex() + 1 ) % count() ); } // Ctrl + numbers else if ( mod == Qt::ControlModifier && ( c >= '1' && c <= '8' ) ) { LOG(logDEBUG) << "number " << c; int new_index = c - '0'; if ( new_index <= count() ) setCurrentIndex( new_index - 1 ); } // Ctrl + 9 else if ( mod == Qt::ControlModifier && c == '9' ) { LOG(logDEBUG) << "last"; setCurrentIndex( count() - 1 ); } else if ( mod == Qt::ControlModifier && (c == 'q' || c == 'w') ) { LOG(logDEBUG) << "Close tab " << currentIndex(); emit tabCloseRequested( currentIndex() ); } else { QTabWidget::keyPressEvent( event ); } } void TabbedCrawlerWidget::setTabDataStatus( int index, DataStatus status ) { LOG(logDEBUG) << "TabbedCrawlerWidget::setTabDataStatus " << index; QLabel* icon_label = dynamic_cast( myTabBar_.tabButton( index, QTabBar::RightSide ) ); if ( icon_label ) { const QIcon* icon; switch ( status ) { case DataStatus::OLD_DATA: icon = &olddata_icon_; break; case DataStatus::NEW_DATA: icon = &newdata_icon_; break; case DataStatus::NEW_FILTERED_DATA: icon = &newfiltered_icon_; break; } icon_label->setPixmap ( icon->pixmap(12,12) ); } }