#5621 Delta case : Create delta case from two selected cases

This commit is contained in:
Magne Sjaastad 2020-03-19 11:46:24 +01:00
parent b01d826acf
commit 9ef51a5e98
5 changed files with 57 additions and 10 deletions

View File

@ -37,10 +37,9 @@ CAF_CMD_SOURCE_INIT( RicNewDerivedSummaryFeature, "RicNewDerivedSummaryFeature"
//--------------------------------------------------------------------------------------------------
bool RicNewDerivedSummaryFeature::isCommandEnabled()
{
std::vector<RimSummaryCaseMainCollection*> mainColls =
caf::selectedObjectsByTypeStrict<RimSummaryCaseMainCollection*>();
if ( mainCollection() ) return true;
return mainColls.size() == 1;
return false;
}
//--------------------------------------------------------------------------------------------------
@ -48,13 +47,20 @@ bool RicNewDerivedSummaryFeature::isCommandEnabled()
//--------------------------------------------------------------------------------------------------
void RicNewDerivedSummaryFeature::onActionTriggered( bool isChecked )
{
if ( isCommandEnabled() )
auto mainColl = mainCollection();
if ( mainColl )
{
auto project = RiaApplication::instance()->project();
auto mainColl = project->firstSummaryCaseMainCollection();
auto derivedCase = new RimDerivedSummaryCase;
auto selectedCases = twoSelectedSummaryCases();
if ( !selectedCases.empty() )
{
derivedCase->setSummaryCases( selectedCases[0], selectedCases[1] );
derivedCase->createSummaryReaderInterface();
}
mainColl->addCase( derivedCase );
derivedCase->updateDisplayNameFromCases();
mainColl->updateConnectedEditors();
RiuPlotMainWindowTools::selectAsCurrentItem( derivedCase );
@ -69,3 +75,35 @@ void RicNewDerivedSummaryFeature::setupActionLook( QAction* actionToSetup )
actionToSetup->setText( "New Delta Summary Case" );
// actionToSetup->setIcon( QIcon( ":/SummaryEnsemble16x16.png" ) );
}
//--------------------------------------------------------------------------------------------------
///
//--------------------------------------------------------------------------------------------------
RimSummaryCaseMainCollection* RicNewDerivedSummaryFeature::mainCollection()
{
std::vector<RimSummaryCaseMainCollection*> mainColls =
caf::selectedObjectsByTypeStrict<RimSummaryCaseMainCollection*>();
if ( mainColls.size() == 1 ) return mainColls.front();
auto sumCases = twoSelectedSummaryCases();
if ( !sumCases.empty() )
{
RimSummaryCaseMainCollection* mainColl = nullptr;
sumCases.front()->firstAncestorOfType( mainColl );
return mainColl;
}
return nullptr;
}
//--------------------------------------------------------------------------------------------------
///
//--------------------------------------------------------------------------------------------------
std::vector<RimSummaryCase*> RicNewDerivedSummaryFeature::twoSelectedSummaryCases()
{
auto sumCases = caf::selectedObjectsByTypeStrict<RimSummaryCase*>();
if ( sumCases.size() == 2 ) return sumCases;
return {};
}

View File

@ -20,6 +20,9 @@
#include "cafCmdFeature.h"
class RimSummaryCase;
class RimSummaryCaseMainCollection;
//==================================================================================================
///
//==================================================================================================
@ -32,4 +35,8 @@ protected:
bool isCommandEnabled() override;
void onActionTriggered( bool isChecked ) override;
void setupActionLook( QAction* actionToSetup ) override;
private:
static RimSummaryCaseMainCollection* mainCollection();
static std::vector<RimSummaryCase*> twoSelectedSummaryCases();
};

View File

@ -876,6 +876,7 @@ caf::CmdFeatureMenuBuilder RimContextCommandBuilder::commandsFromSelection()
menuBuilder << "RicNewDefaultSummaryPlotFeature";
menuBuilder << "RicNewSummaryCrossPlotFeature";
menuBuilder << "RicSummaryCurveSwitchAxisFeature";
menuBuilder << "RicNewDerivedSummaryFeature";
menuBuilder.addSeparator();
menuBuilder << "RicConvertGroupToEnsembleFeature";
menuBuilder.addSeparator();

View File

@ -283,7 +283,7 @@ void RimDerivedSummaryCase::clearData( const RifEclipseSummaryAddress& address )
//--------------------------------------------------------------------------------------------------
///
//--------------------------------------------------------------------------------------------------
void RimDerivedSummaryCase::updateNameFromInputCases()
void RimDerivedSummaryCase::updateDisplayNameFromCases()
{
QString case1Name = "None";
QString case2Name = "None";
@ -370,7 +370,7 @@ void RimDerivedSummaryCase::fieldChangedByUi( const caf::PdmFieldHandle* changed
if ( reloadData )
{
updateNameFromInputCases();
updateDisplayNameFromCases();
m_dataCache.clear();

View File

@ -64,6 +64,8 @@ public:
RifSummaryReaderInterface* summaryReader() override;
void updateFilePathsFromProjectPath( const QString& newProjectPath, const QString& oldProjectPath ) override;
void updateDisplayNameFromCases();
protected:
QString caseName() const override;
@ -75,7 +77,6 @@ private:
void defineUiOrdering( QString uiConfigName, caf::PdmUiOrdering& uiOrdering ) override;
void clearData( const RifEclipseSummaryAddress& address );
void updateNameFromInputCases();
private:
caf::PdmPtrField<RimSummaryCase*> m_summaryCase1;