mirror of
https://github.com/OPM/ResInsight.git
synced 2025-02-25 18:55:39 -06:00
#3528 Make Casing Design a child object under well path.
This commit is contained in:
@@ -17,9 +17,11 @@
|
|||||||
/////////////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////////////
|
||||||
#include "RicDeleteWellPathAttributeFeature.h"
|
#include "RicDeleteWellPathAttributeFeature.h"
|
||||||
|
|
||||||
|
#include "RimProject.h"
|
||||||
#include "RimWellPath.h"
|
#include "RimWellPath.h"
|
||||||
#include "RimWellPathAttribute.h"
|
#include "RimWellPathAttribute.h"
|
||||||
#include "RimWellPathAttributeCollection.h"
|
#include "RimWellPathAttributeCollection.h"
|
||||||
|
#include "Riu3DMainWindowTools.h"
|
||||||
|
|
||||||
#include "cafSelectionManager.h"
|
#include "cafSelectionManager.h"
|
||||||
#include <QAction>
|
#include <QAction>
|
||||||
@@ -60,6 +62,14 @@ void RicDeleteWellPathAttributeFeature::onActionTriggered(bool isChecked)
|
|||||||
wellPathAttributeCollection->deleteAttribute(attributeToDelete);
|
wellPathAttributeCollection->deleteAttribute(attributeToDelete);
|
||||||
}
|
}
|
||||||
wellPathAttributeCollection->updateAllRequiredEditors();
|
wellPathAttributeCollection->updateAllRequiredEditors();
|
||||||
|
|
||||||
|
if (wellPathAttributeCollection->attributes().empty())
|
||||||
|
{
|
||||||
|
RimWellPath* wellPath = nullptr;
|
||||||
|
wellPathAttributeCollection->firstAncestorOrThisOfTypeAsserted(wellPath);
|
||||||
|
wellPath->updateConnectedEditors();
|
||||||
|
Riu3DMainWindowTools::selectAsCurrentItem(wellPath);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -17,9 +17,11 @@
|
|||||||
/////////////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////////////
|
||||||
#include "RicNewWellPathAttributeFeature.h"
|
#include "RicNewWellPathAttributeFeature.h"
|
||||||
|
|
||||||
|
#include "RimProject.h"
|
||||||
#include "RimWellPath.h"
|
#include "RimWellPath.h"
|
||||||
#include "RimWellPathAttribute.h"
|
#include "RimWellPathAttribute.h"
|
||||||
#include "RimWellPathAttributeCollection.h"
|
#include "RimWellPathAttributeCollection.h"
|
||||||
|
#include "Riu3DMainWindowTools.h"
|
||||||
|
|
||||||
#include "cafSelectionManager.h"
|
#include "cafSelectionManager.h"
|
||||||
|
|
||||||
@@ -86,6 +88,10 @@ void RicNewWellPathAttributeFeature::onActionTriggered(bool isChecked)
|
|||||||
|
|
||||||
attributeCollections[0]->insertAttribute(nullptr, attribute);
|
attributeCollections[0]->insertAttribute(nullptr, attribute);
|
||||||
attributeCollections[0]->updateAllRequiredEditors();
|
attributeCollections[0]->updateAllRequiredEditors();
|
||||||
|
|
||||||
|
wellPath->updateConnectedEditors();
|
||||||
|
Riu3DMainWindowTools::selectAsCurrentItem(attributeCollections[0]);
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -101,12 +107,17 @@ void RicNewWellPathAttributeFeature::setupActionLook(QAction* actionToSetup)
|
|||||||
{
|
{
|
||||||
actionToSetup->setText(QString("Insert New Attribute before %1").arg(attributes[0]->componentTypeLabel()));
|
actionToSetup->setText(QString("Insert New Attribute before %1").arg(attributes[0]->componentTypeLabel()));
|
||||||
actionToSetup->setIcon(QIcon(":/Well.png"));
|
actionToSetup->setIcon(QIcon(":/Well.png"));
|
||||||
}
|
}
|
||||||
else
|
else if (caf::SelectionManager::instance()->selectedItemOfType<RimWellPathAttributeCollection>())
|
||||||
{
|
{
|
||||||
actionToSetup->setText("Append New Attribute");
|
actionToSetup->setText("Append New Attribute");
|
||||||
actionToSetup->setIcon(QIcon(":/Well.png"));
|
actionToSetup->setIcon(QIcon(":/Well.png"));
|
||||||
}
|
}
|
||||||
|
else if(caf::SelectionManager::instance()->selectedItemOfType<RimWellPath>())
|
||||||
|
{
|
||||||
|
actionToSetup->setText("Create Casing Design");
|
||||||
|
actionToSetup->setIcon(QIcon(":/Well.png"));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -289,13 +289,11 @@ caf::CmdFeatureMenuBuilder RimContextCommandBuilder::commandsFromSelection()
|
|||||||
menuBuilder << "RicNewWellPathIntersectionFeature";
|
menuBuilder << "RicNewWellPathIntersectionFeature";
|
||||||
|
|
||||||
menuBuilder.addSeparator();
|
menuBuilder.addSeparator();
|
||||||
|
|
||||||
menuBuilder.subMenuStart("Completions", QIcon(":/FishBoneGroup16x16.png"));
|
menuBuilder.subMenuStart("Completions", QIcon(":/FishBoneGroup16x16.png"));
|
||||||
menuBuilder << "RicNewWellPathFractureFeature";
|
menuBuilder << "RicNewWellPathFractureFeature";
|
||||||
menuBuilder << "RicNewFishbonesSubsFeature";
|
menuBuilder << "RicNewFishbonesSubsFeature";
|
||||||
menuBuilder << "RicNewPerforationIntervalFeature";
|
menuBuilder << "RicNewPerforationIntervalFeature";
|
||||||
menuBuilder << "RicNewValveFeature";
|
menuBuilder << "RicNewValveFeature";
|
||||||
|
|
||||||
menuBuilder << "RicEditPerforationCollectionFeature";
|
menuBuilder << "RicEditPerforationCollectionFeature";
|
||||||
menuBuilder.subMenuEnd();
|
menuBuilder.subMenuEnd();
|
||||||
|
|
||||||
@@ -309,6 +307,7 @@ caf::CmdFeatureMenuBuilder RimContextCommandBuilder::commandsFromSelection()
|
|||||||
menuBuilder << "RicShowWellPlanFeature";
|
menuBuilder << "RicShowWellPlanFeature";
|
||||||
}
|
}
|
||||||
menuBuilder << "RicCreateMultipleFracturesFeature";
|
menuBuilder << "RicCreateMultipleFracturesFeature";
|
||||||
|
menuBuilder << "RicNewWellPathAttributeFeature";
|
||||||
|
|
||||||
menuBuilder << "Separator";
|
menuBuilder << "Separator";
|
||||||
|
|
||||||
|
|||||||
@@ -118,10 +118,9 @@ RimWellPath::RimWellPath()
|
|||||||
m_wellLogFile_OBSOLETE.uiCapability()->setUiHidden(true);
|
m_wellLogFile_OBSOLETE.uiCapability()->setUiHidden(true);
|
||||||
m_wellLogFile_OBSOLETE.xmlCapability()->setIOWritable(false);
|
m_wellLogFile_OBSOLETE.xmlCapability()->setIOWritable(false);
|
||||||
|
|
||||||
CAF_PDM_InitFieldNoDefault(&m_wellPathAttributes, "WellPathAttributes", "", "", "", "");
|
CAF_PDM_InitFieldNoDefault(&m_wellPathAttributes, "WellPathAttributes", "Casing Design Rubbish", "", "", "");
|
||||||
m_wellPathAttributes = new RimWellPathAttributeCollection;
|
m_wellPathAttributes = new RimWellPathAttributeCollection;
|
||||||
m_wellPathAttributes->uiCapability()->setUiTreeHidden(true);
|
m_wellPathAttributes->uiCapability()->setUiTreeHidden(true);
|
||||||
m_wellPathAttributes->uiCapability()->setUiTreeChildrenHidden(true);
|
|
||||||
|
|
||||||
m_wellPath = nullptr;
|
m_wellPath = nullptr;
|
||||||
}
|
}
|
||||||
@@ -564,8 +563,6 @@ void RimWellPath::defineUiOrdering(QString uiConfigName, caf::PdmUiOrdering& uiO
|
|||||||
formationFileInfoGroup->add(&m_wellPathFormationFilePath);
|
formationFileInfoGroup->add(&m_wellPathFormationFilePath);
|
||||||
formationFileInfoGroup->add(&m_formationKeyInFile);
|
formationFileInfoGroup->add(&m_formationKeyInFile);
|
||||||
|
|
||||||
m_wellPathAttributes->uiOrdering(uiConfigName, uiOrdering);
|
|
||||||
|
|
||||||
uiOrdering.skipRemainingFields(true);
|
uiOrdering.skipRemainingFields(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -578,12 +575,17 @@ void RimWellPath::defineUiTreeOrdering(caf::PdmUiTreeOrdering& uiTreeOrdering, Q
|
|||||||
|
|
||||||
if (m_completions->hasCompletions())
|
if (m_completions->hasCompletions())
|
||||||
{
|
{
|
||||||
uiTreeOrdering.add(&m_completions);
|
uiTreeOrdering.add(m_completions());
|
||||||
}
|
}
|
||||||
|
|
||||||
if (m_3dWellLogCurves->has3dWellLogCurves())
|
if (m_3dWellLogCurves->has3dWellLogCurves())
|
||||||
{
|
{
|
||||||
uiTreeOrdering.add(&m_3dWellLogCurves);
|
uiTreeOrdering.add(m_3dWellLogCurves());
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!m_wellPathAttributes->attributes().empty())
|
||||||
|
{
|
||||||
|
uiTreeOrdering.add(m_wellPathAttributes());
|
||||||
}
|
}
|
||||||
|
|
||||||
uiTreeOrdering.skipRemainingChildren(true);
|
uiTreeOrdering.skipRemainingChildren(true);
|
||||||
|
|||||||
@@ -22,6 +22,7 @@
|
|||||||
|
|
||||||
#include "cafCmdFeatureMenuBuilder.h"
|
#include "cafCmdFeatureMenuBuilder.h"
|
||||||
#include "cafPdmUiTableViewEditor.h"
|
#include "cafPdmUiTableViewEditor.h"
|
||||||
|
#include "cafPdmUiTreeOrdering.h"
|
||||||
|
|
||||||
CAF_PDM_SOURCE_INIT(RimWellPathAttributeCollection, "WellPathAttributes");
|
CAF_PDM_SOURCE_INIT(RimWellPathAttributeCollection, "WellPathAttributes");
|
||||||
|
|
||||||
@@ -30,12 +31,11 @@ CAF_PDM_SOURCE_INIT(RimWellPathAttributeCollection, "WellPathAttributes");
|
|||||||
//--------------------------------------------------------------------------------------------------
|
//--------------------------------------------------------------------------------------------------
|
||||||
RimWellPathAttributeCollection::RimWellPathAttributeCollection()
|
RimWellPathAttributeCollection::RimWellPathAttributeCollection()
|
||||||
{
|
{
|
||||||
CAF_PDM_InitObject("WellPathAttributes", ":/Well.png", "", "");
|
CAF_PDM_InitObject("Casing Design", ":/CompletionsSymbol16x16", "", "");
|
||||||
|
|
||||||
CAF_PDM_InitFieldNoDefault(&m_attributes, "Attributes", "", "", "", "");
|
CAF_PDM_InitFieldNoDefault(&m_attributes, "Attributes", "Casing Design Attributes", "", "", "");
|
||||||
m_attributes.uiCapability()->setUiEditorTypeName(caf::PdmUiTableViewEditor::uiEditorTypeName());
|
m_attributes.uiCapability()->setUiEditorTypeName(caf::PdmUiTableViewEditor::uiEditorTypeName());
|
||||||
m_attributes.uiCapability()->setUiTreeChildrenHidden(true);
|
m_attributes.uiCapability()->setUiLabelPosition(caf::PdmUiItemInfo::TOP);
|
||||||
m_attributes.uiCapability()->setUiLabelPosition(caf::PdmUiItemInfo::HIDDEN);
|
|
||||||
m_attributes.uiCapability()->setCustomContextMenuEnabled(true);
|
m_attributes.uiCapability()->setCustomContextMenuEnabled(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -137,6 +137,13 @@ void RimWellPathAttributeCollection::defineEditorAttribute(const caf::PdmFieldHa
|
|||||||
//--------------------------------------------------------------------------------------------------
|
//--------------------------------------------------------------------------------------------------
|
||||||
void RimWellPathAttributeCollection::defineUiOrdering(QString uiConfigName, caf::PdmUiOrdering& uiOrdering)
|
void RimWellPathAttributeCollection::defineUiOrdering(QString uiConfigName, caf::PdmUiOrdering& uiOrdering)
|
||||||
{
|
{
|
||||||
caf::PdmUiGroup* attrGroup = uiOrdering.addNewGroup("Well Path Attributes");
|
uiOrdering.add(&m_attributes);
|
||||||
attrGroup->add(&m_attributes);
|
}
|
||||||
|
|
||||||
|
//--------------------------------------------------------------------------------------------------
|
||||||
|
///
|
||||||
|
//--------------------------------------------------------------------------------------------------
|
||||||
|
void RimWellPathAttributeCollection::defineUiTreeOrdering(caf::PdmUiTreeOrdering& uiTreeOrdering, QString uiConfigName /*= ""*/)
|
||||||
|
{
|
||||||
|
uiTreeOrdering.skipRemainingChildren(true);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -39,8 +39,10 @@ public:
|
|||||||
|
|
||||||
protected:
|
protected:
|
||||||
void defineCustomContextMenu(const caf::PdmFieldHandle* fieldNeedingMenu, QMenu* menu, QWidget* fieldEditorWidget) override;
|
void defineCustomContextMenu(const caf::PdmFieldHandle* fieldNeedingMenu, QMenu* menu, QWidget* fieldEditorWidget) override;
|
||||||
void defineEditorAttribute(const caf::PdmFieldHandle* field, QString uiConfigName, caf::PdmUiEditorAttribute* attribute) override;
|
void defineEditorAttribute(const caf::PdmFieldHandle* field, QString uiConfigName, caf::PdmUiEditorAttribute* attribute) override;
|
||||||
void defineUiOrdering(QString uiConfigName, caf::PdmUiOrdering& uiOrdering) override;
|
void defineUiOrdering(QString uiConfigName, caf::PdmUiOrdering& uiOrdering) override;
|
||||||
|
void defineUiTreeOrdering(caf::PdmUiTreeOrdering& uiTreeOrdering, QString uiConfigName = "") override;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
caf::PdmChildArrayField<RimWellPathAttribute*> m_attributes;
|
caf::PdmChildArrayField<RimWellPathAttribute*> m_attributes;
|
||||||
};
|
};
|
||||||
@@ -405,9 +405,9 @@ void RiuViewerCommands::displayContextMenu(QMouseEvent* event)
|
|||||||
menuBuilder.subMenuEnd();
|
menuBuilder.subMenuEnd();
|
||||||
|
|
||||||
menuBuilder.addSeparator();
|
menuBuilder.addSeparator();
|
||||||
|
menuBuilder << "RicNewWellPathAttributeFeature";
|
||||||
menuBuilder.subMenuStart("Completions", QIcon(":/FishBoneGroup16x16.png"));
|
menuBuilder.subMenuStart("Completions", QIcon(":/FishBoneGroup16x16.png"));
|
||||||
|
|
||||||
menuBuilder << "RicNewWellPathFractureAtPosFeature";
|
menuBuilder << "RicNewWellPathFractureAtPosFeature";
|
||||||
menuBuilder << "RicNewFishbonesSubsAtMeasuredDepthFeature";
|
menuBuilder << "RicNewFishbonesSubsAtMeasuredDepthFeature";
|
||||||
menuBuilder << "RicNewPerforationIntervalAtMeasuredDepthFeature";
|
menuBuilder << "RicNewPerforationIntervalAtMeasuredDepthFeature";
|
||||||
|
|||||||
Reference in New Issue
Block a user