mirror of
https://github.com/OPM/ResInsight.git
synced 2025-01-24 15:26:48 -06:00
Revert "Improved default parsing of visible items to establish root items in the tree view"
This reverts commit 550eccc521
.
This commit is contained in:
parent
7956269fe4
commit
e3bfca8174
@ -63,7 +63,6 @@ protected:
|
||||
/// Fill up the uiOrdering object with groups and field references to create the gui structure
|
||||
/// If the uiOrdering is empty, it is interpreted as meaning all fields w/o grouping.
|
||||
virtual void defineUiOrdering(QString uiConfigName, PdmUiOrdering& uiOrdering) {}
|
||||
friend class PdmUiTreeViewModel;
|
||||
|
||||
/// Override to customize the tree representations of the object hierarchy.
|
||||
/// If the PdmUiTreeOrdering is empty, it is interpreted as meaning all fields containing child objects in order
|
||||
|
@ -37,8 +37,6 @@
|
||||
|
||||
#include "cafPdmUiTreeViewModel.h"
|
||||
|
||||
#include "cafPdmChildArrayField.h"
|
||||
#include "cafPdmChildField.h"
|
||||
#include "cafPdmField.h"
|
||||
#include "cafPdmObject.h"
|
||||
#include "cafPdmUiTreeItemEditor.h"
|
||||
@ -72,42 +70,28 @@ void PdmUiTreeViewModel::setPdmItemRoot(PdmUiItem* rootItem)
|
||||
return;
|
||||
}
|
||||
|
||||
PdmUiTreeOrdering* invisibleRoot = NULL;
|
||||
if (rootItem)
|
||||
{
|
||||
std::vector<PdmUiItem*> visibleItems;
|
||||
findFirstVisibleUiItemInAllBranches(rootItem, visibleItems, m_uiConfigName);
|
||||
PdmUiTreeOrdering* newRoot = NULL;
|
||||
PdmUiFieldHandle* field = dynamic_cast<PdmUiFieldHandle*> (rootItem);
|
||||
|
||||
if (visibleItems.size() > 0)
|
||||
{
|
||||
invisibleRoot = new PdmUiTreeOrdering("Invisible Tree Root", "");
|
||||
|
||||
for (size_t i = 0; i < visibleItems.size(); i++)
|
||||
{
|
||||
PdmUiTreeOrdering* nextTreeOrdering = NULL;
|
||||
|
||||
PdmUiFieldHandle* field = dynamic_cast<PdmUiFieldHandle*> (visibleItems[i]);
|
||||
if (field)
|
||||
{
|
||||
nextTreeOrdering = new PdmUiTreeOrdering(field->fieldHandle());
|
||||
PdmUiObjectHandle::expandUiTree(nextTreeOrdering, m_uiConfigName);
|
||||
newRoot = new PdmUiTreeOrdering(field->fieldHandle());
|
||||
PdmUiObjectHandle::expandUiTree(newRoot, m_uiConfigName);
|
||||
}
|
||||
else
|
||||
{
|
||||
PdmUiObjectHandle * obj = dynamic_cast<PdmUiObjectHandle*> (visibleItems[i]);
|
||||
PdmUiObjectHandle * obj = dynamic_cast<PdmUiObjectHandle*> (rootItem);
|
||||
if (obj)
|
||||
{
|
||||
nextTreeOrdering = obj->uiTreeOrdering(m_uiConfigName);
|
||||
newRoot = obj->uiTreeOrdering(m_uiConfigName);
|
||||
}
|
||||
}
|
||||
|
||||
assert(nextTreeOrdering);
|
||||
invisibleRoot->appendChild(nextTreeOrdering);
|
||||
}
|
||||
}
|
||||
}
|
||||
assert( newRoot || rootItem == NULL ); // Only fields, objects or NULL is allowed.
|
||||
|
||||
this->resetTree(invisibleRoot);
|
||||
if (newRoot) newRoot->debugDump(0);
|
||||
|
||||
this->resetTree(newRoot);
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
@ -705,78 +689,5 @@ QVariant PdmUiTreeViewModel::headerData(int section, Qt::Orientation orientation
|
||||
return QVariant();
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
/// Do a search recursively to find the first visible object of all child branches
|
||||
/// If the incoming object is visible, this is the only object returned
|
||||
/// defineUiTreeOrdering is used to
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
void PdmUiTreeViewModel::findFirstVisibleUiItemInAllBranches(PdmUiItem* uiItem, std::vector<PdmUiItem*>& visibleItems, const QString& uiConfigName)
|
||||
{
|
||||
if (!uiItem) return;
|
||||
|
||||
if (!uiItem->isUiHidden(uiConfigName))
|
||||
{
|
||||
visibleItems.push_back(uiItem);
|
||||
}
|
||||
else
|
||||
{
|
||||
// Check if ui tree ordering is defined in the data model
|
||||
PdmUiObjectHandle* uiObjectHandle = dynamic_cast<PdmUiObjectHandle*> (uiItem);
|
||||
if (uiObjectHandle)
|
||||
{
|
||||
PdmUiTreeOrdering treeOrderingDefinedByApplication("", "");
|
||||
uiObjectHandle->defineUiTreeOrdering(treeOrderingDefinedByApplication, uiConfigName);
|
||||
if (treeOrderingDefinedByApplication.childCount() > 0)
|
||||
{
|
||||
for (int i = 0; i < treeOrderingDefinedByApplication.childCount(); i++)
|
||||
{
|
||||
// The referenced objects in uiOrdering might be set as hidden
|
||||
// Do a recursive search from the referenced objects to find first visible ui item
|
||||
findFirstVisibleUiItemInAllBranches(treeOrderingDefinedByApplication.child(i)->activeItem(), visibleItems, uiConfigName);
|
||||
}
|
||||
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
if (uiItem->isUiChildrenHidden(uiConfigName))
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
PdmUiFieldHandle* field = dynamic_cast<PdmUiFieldHandle*> (uiItem);
|
||||
if (field)
|
||||
{
|
||||
std::vector<caf::PdmObjectHandle*> children;
|
||||
field->fieldHandle()->childObjects(&children);
|
||||
|
||||
for (size_t i = 0; i < children.size(); i++)
|
||||
{
|
||||
findFirstVisibleUiItemInAllBranches(uiObj(children[i]), visibleItems, uiConfigName);
|
||||
}
|
||||
}
|
||||
|
||||
if (uiObjectHandle)
|
||||
{
|
||||
std::vector<PdmFieldHandle*> fields;
|
||||
uiObjectHandle->owner()->fields(fields);
|
||||
|
||||
for (size_t i = 0; i < fields.size(); i++)
|
||||
{
|
||||
if (dynamic_cast<PdmChildArrayFieldHandle*>(fields[i]))
|
||||
{
|
||||
// Always show a container object, even if the container is empty
|
||||
findFirstVisibleUiItemInAllBranches(fields[i]->uiCapability(), visibleItems, uiConfigName);
|
||||
}
|
||||
else if (fields[i]->hasChildObjects())
|
||||
{
|
||||
// Show a child object only if an object is present
|
||||
findFirstVisibleUiItemInAllBranches(fields[i]->uiCapability(), visibleItems, uiConfigName);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
} // end namespace caf
|
||||
|
@ -83,8 +83,6 @@ private:
|
||||
void updateEditorsForSubTree(PdmUiTreeOrdering* root);
|
||||
static int findChildItemIndex(const PdmUiTreeOrdering * parent, const PdmUiItem* pdmItemToFindInChildren);
|
||||
|
||||
static void findFirstVisibleUiItemInAllBranches(PdmUiItem* uiItem, std::vector<PdmUiItem*>& visibleItems, const QString& uiConfigName);
|
||||
|
||||
PdmUiTreeOrdering* m_treeOrderingRoot;
|
||||
QStringList m_columnHeaders;
|
||||
QString m_uiConfigName;
|
||||
|
Loading…
Reference in New Issue
Block a user