mirror of
https://github.com/swift-project/pilotclient.git
synced 2026-03-24 07:55:35 +08:00
154 lines
5.5 KiB
C++
154 lines
5.5 KiB
C++
/* Copyright (C) 2013
|
|
* swift project Community / Contributors
|
|
*
|
|
* This file is part of swift Project. It is subject to the license terms in the LICENSE file found in the top-level
|
|
* directory of this distribution and at http://www.swift-project.org/license.html. No part of swift project,
|
|
* including this file, may be copied, modified, propagated, or distributed except according to the terms
|
|
* contained in the LICENSE file.
|
|
*/
|
|
|
|
#include "blackgui/dockwidgetinfoarea.h"
|
|
#include "blackgui/infoarea.h"
|
|
#include "components/enablefordockwidgetinfoarea.h"
|
|
#include "blackmisc/icons.h"
|
|
|
|
using namespace BlackGui::Components;
|
|
|
|
namespace BlackGui
|
|
{
|
|
CDockWidgetInfoArea::CDockWidgetInfoArea(QWidget *parent) : CDockWidget(parent)
|
|
{
|
|
// void
|
|
}
|
|
|
|
const CInfoArea *CDockWidgetInfoArea::getParentInfoArea() const
|
|
{
|
|
const CInfoArea *ia = dynamic_cast<const CInfoArea *>(this->parent());
|
|
Q_ASSERT(ia);
|
|
return ia;
|
|
}
|
|
|
|
CInfoArea *CDockWidgetInfoArea::getParentInfoArea()
|
|
{
|
|
CInfoArea *ia = dynamic_cast<CInfoArea *>(this->parent());
|
|
Q_ASSERT(ia);
|
|
return ia;
|
|
}
|
|
|
|
bool CDockWidgetInfoArea::isSelectedDockWidget() const
|
|
{
|
|
const CInfoArea *ia = getParentInfoArea();
|
|
if (!ia) { return false; }
|
|
return ia->isSelectedDockWidgetInfoArea(this);
|
|
}
|
|
|
|
bool CDockWidgetInfoArea::isVisibleWidget() const
|
|
{
|
|
// if the widget is invisible we are done
|
|
// but if it is visible, there is no guarantee it can be seen by the user
|
|
if (!this->isVisible()) { return false; }
|
|
|
|
// further checks
|
|
if (this->isFloating())
|
|
{
|
|
if (this->isMinimized()) { return false; }
|
|
return true;
|
|
}
|
|
else
|
|
{
|
|
return isSelectedDockWidget();
|
|
}
|
|
}
|
|
|
|
void CDockWidgetInfoArea::addToContextMenu(QMenu *contextMenu) const
|
|
{
|
|
QList<const CInfoArea *> parentInfoAreas = this->findParentInfoAreas();
|
|
Q_ASSERT(!parentInfoAreas.isEmpty());
|
|
if (parentInfoAreas.isEmpty()) return;
|
|
|
|
// Dockable widget's context menu
|
|
CDockWidget::addToContextMenu(contextMenu);
|
|
if (!contextMenu->isEmpty()) { contextMenu->addSeparator(); }
|
|
|
|
// first info area, myself's direct parent info area
|
|
parentInfoAreas.first()->addToContextMenu(contextMenu);
|
|
|
|
// top info areas other than direct parent
|
|
// (parent's parent when nested info areas are used)
|
|
if (parentInfoAreas.size() < 2) { return; }
|
|
contextMenu->addSeparator();
|
|
for (int i = 1; i < parentInfoAreas.size(); i++)
|
|
{
|
|
const CInfoArea *infoArea = parentInfoAreas.at(i);
|
|
QString title(infoArea->windowTitle());
|
|
if (title.isEmpty())
|
|
{
|
|
title = infoArea->objectName();
|
|
}
|
|
QMenu *m = contextMenu->addMenu(title);
|
|
infoArea->addToContextMenu(m);
|
|
}
|
|
}
|
|
|
|
void CDockWidgetInfoArea::initialFloating()
|
|
{
|
|
CDockWidget::initialFloating(); // initial floating to init position & size
|
|
QList<CEnableForDockWidgetInfoArea *> infoAreaDockWidgets = this->findEmbeddedDockWidgetInfoAreaComponents();
|
|
foreach(CEnableForDockWidgetInfoArea * dwia, infoAreaDockWidgets)
|
|
{
|
|
Q_ASSERT_X(dwia, Q_FUNC_INFO, "Missing info area");
|
|
dwia->setParentDockWidgetInfoArea(this);
|
|
}
|
|
}
|
|
|
|
QList<CEnableForDockWidgetInfoArea *> CDockWidgetInfoArea::findEmbeddedDockWidgetInfoAreaComponents()
|
|
{
|
|
QList<QWidget *> widgets = this->findChildren<QWidget *>();
|
|
QList<CEnableForDockWidgetInfoArea *> widgetsWithDockWidgetInfoAreaComponent;
|
|
foreach(QWidget * w, widgets)
|
|
{
|
|
Q_ASSERT(w);
|
|
CEnableForDockWidgetInfoArea *dwc = dynamic_cast<Components::CEnableForDockWidgetInfoArea *>(w);
|
|
if (dwc)
|
|
{
|
|
widgetsWithDockWidgetInfoAreaComponent.append(dwc);
|
|
}
|
|
}
|
|
QList<CDockWidgetInfoArea *> nestedInfoAreas = this->findNestedInfoAreas();
|
|
if (nestedInfoAreas.isEmpty()) return widgetsWithDockWidgetInfoAreaComponent;
|
|
|
|
// we have to exclude the nested embedded areas
|
|
foreach(CDockWidgetInfoArea * ia, nestedInfoAreas)
|
|
{
|
|
QList<CEnableForDockWidgetInfoArea *> nestedInfoAreaComponents = ia->findEmbeddedDockWidgetInfoAreaComponents();
|
|
if (nestedInfoAreaComponents.isEmpty()) { continue; }
|
|
foreach(CEnableForDockWidgetInfoArea * iac, nestedInfoAreaComponents)
|
|
{
|
|
bool r = widgetsWithDockWidgetInfoAreaComponent.removeOne(iac);
|
|
Q_ASSERT(r); // why is the nested component not in the child list?
|
|
Q_UNUSED(r);
|
|
}
|
|
}
|
|
return widgetsWithDockWidgetInfoAreaComponent;
|
|
}
|
|
|
|
QList<CDockWidgetInfoArea *> CDockWidgetInfoArea::findNestedInfoAreas()
|
|
{
|
|
QList<CDockWidgetInfoArea *> nestedInfoAreas = this->findChildren<CDockWidgetInfoArea *>();
|
|
return nestedInfoAreas;
|
|
}
|
|
|
|
const QList<const CInfoArea *> CDockWidgetInfoArea::findParentInfoAreas() const
|
|
{
|
|
QList<const CInfoArea *> parents;
|
|
QWidget *currentWidget = this->parentWidget();
|
|
while (currentWidget)
|
|
{
|
|
const CInfoArea *ia = qobject_cast<CInfoArea *>(currentWidget);
|
|
if (ia) { parents.append(ia); }
|
|
currentWidget = currentWidget->parentWidget();
|
|
}
|
|
return parents;
|
|
}
|
|
} // namespace
|