Fixed proper selection and deselection of current tab in tabbar

This commit is contained in:
Uwe Kindler 2018-11-03 21:48:35 +01:00
parent 72ec61a043
commit 188624440b
3 changed files with 20 additions and 9 deletions

View File

@ -244,7 +244,7 @@ void CDockAreaTabBar::setCurrentIndex(int index)
return; return;
} }
if (index < 0 || index > (count() - 1)) if (index < -1 || index > (count() - 1))
{ {
qWarning() << Q_FUNC_INFO << "Invalid index" << index; qWarning() << Q_FUNC_INFO << "Invalid index" << index;
return; return;
@ -275,7 +275,7 @@ void CDockAreaTabBar::insertTab(int Index, CDockWidgetTab* Tab)
emit tabInserted(Index); emit tabInserted(Index);
if (Index <= d->CurrentIndex) if (Index <= d->CurrentIndex)
{ {
setCurrentIndex(d->CurrentIndex++); setCurrentIndex(d->CurrentIndex + 1);
} }
} }
@ -352,7 +352,14 @@ int CDockAreaTabBar::currentIndex() const
//=========================================================================== //===========================================================================
CDockWidgetTab* CDockAreaTabBar::currentTab() const CDockWidgetTab* CDockAreaTabBar::currentTab() const
{ {
return qobject_cast<CDockWidgetTab*>(d->TabsLayout->itemAt(d->CurrentIndex)->widget()); if (d->CurrentIndex < 0)
{
return nullptr;
}
else
{
return qobject_cast<CDockWidgetTab*>(d->TabsLayout->itemAt(d->CurrentIndex)->widget());
}
} }
@ -378,9 +385,9 @@ void CDockAreaTabBar::onTabClicked()
//=========================================================================== //===========================================================================
CDockWidgetTab* CDockAreaTabBar::tab(int Index) const CDockWidgetTab* CDockAreaTabBar::tab(int Index) const
{ {
if (Index >= count()) if (Index >= count() || Index < 0)
{ {
return 0; return nullptr;
} }
return qobject_cast<CDockWidgetTab*>(d->TabsLayout->itemAt(Index)->widget()); return qobject_cast<CDockWidgetTab*>(d->TabsLayout->itemAt(Index)->widget());
} }
@ -456,7 +463,7 @@ void CDockAreaTabBar::closeTab(int Index)
} }
auto Tab = tab(Index); auto Tab = tab(Index);
if (!Tab->isVisibleTo(this)) if (Tab->isHidden())
{ {
return; return;
} }
@ -497,7 +504,7 @@ bool CDockAreaTabBar::isTabOpen(int Index) const
return false; return false;
} }
return tab(Index)->isVisibleTo(this); return !tab(Index)->isHidden();
} }
} // namespace ads } // namespace ads

View File

@ -120,12 +120,12 @@ public:
int count() const; int count() const;
/** /**
* Returns the current index * Returns the current index or -1 if no tab is selected
*/ */
int currentIndex() const; int currentIndex() const;
/** /**
* Returns the current tab * Returns the current tab or a nullptr if no tab is selected.
*/ */
CDockWidgetTab* currentTab() const; CDockWidgetTab* currentTab() const;

View File

@ -243,6 +243,10 @@ void CDockAreaTitleBar::onTabsMenuActionTriggered(QAction* Action)
//============================================================================ //============================================================================
void CDockAreaTitleBar::onCurrentTabChanged(int Index) void CDockAreaTitleBar::onCurrentTabChanged(int Index)
{ {
if (Index < 0)
{
return;
}
CDockWidget* DockWidget = d->TabBar->tab(Index)->dockWidget(); CDockWidget* DockWidget = d->TabBar->tab(Index)->dockWidget();
d->CloseButton->setEnabled(DockWidget->features().testFlag(CDockWidget::DockWidgetClosable)); d->CloseButton->setEnabled(DockWidget->features().testFlag(CDockWidget::DockWidgetClosable));
} }