mirror of
https://github.com/OPM/ResInsight.git
synced 2025-01-08 07:03:25 -06:00
0c90f67dcc
* Refactor interface to PdmObjectHandle and PdmFieldHandle Return objects instead of passing in structures as parameters * Add nodiscard to several functions * Remove redundant this-> * Rename to ptrReferencedObjectsByType
130 lines
4.7 KiB
C++
130 lines
4.7 KiB
C++
/////////////////////////////////////////////////////////////////////////////////
|
|
//
|
|
// Copyright (C) 2015- Statoil ASA
|
|
// Copyright (C) 2015- Ceetron Solutions AS
|
|
//
|
|
// ResInsight is free software: you can redistribute it and/or modify
|
|
// it under the terms of the GNU General Public License as published by
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
// (at your option) any later version.
|
|
//
|
|
// ResInsight is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
// WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
// FITNESS FOR A PARTICULAR PURPOSE.
|
|
//
|
|
// See the GNU General Public License at <http://www.gnu.org/licenses/gpl.html>
|
|
// for more details.
|
|
//
|
|
/////////////////////////////////////////////////////////////////////////////////
|
|
|
|
#include "RicReplaceCaseFeature.h"
|
|
|
|
#include "RiaGuiApplication.h"
|
|
#include "RiaSummaryTools.h"
|
|
|
|
#include "RicImportGeneralDataFeature.h"
|
|
|
|
#include "RimEclipseCase.h"
|
|
#include "RimEclipseResultCase.h"
|
|
#include "RimReloadCaseTools.h"
|
|
#include "RimSummaryCase.h"
|
|
#include "RimSummaryCaseMainCollection.h"
|
|
#include "RimSummaryMultiPlot.h"
|
|
#include "RimSummaryMultiPlotCollection.h"
|
|
#include "RimSummaryPlot.h"
|
|
#include "RimTimeStepFilter.h"
|
|
|
|
#include "Riu3dSelectionManager.h"
|
|
|
|
#include "cafPdmObject.h"
|
|
#include "cafSelectionManager.h"
|
|
|
|
#include <QAction>
|
|
#include <QFileInfo>
|
|
|
|
CAF_CMD_SOURCE_INIT( RicReplaceCaseFeature, "RicReplaceCaseFeature" );
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
bool RicReplaceCaseFeature::isCommandEnabled()
|
|
{
|
|
std::vector<caf::PdmObject*> selectedFormationNamesCollObjs;
|
|
caf::SelectionManager::instance()->objectsByType( &selectedFormationNamesCollObjs );
|
|
for ( caf::PdmObject* pdmObject : selectedFormationNamesCollObjs )
|
|
{
|
|
if ( dynamic_cast<RimEclipseResultCase*>( pdmObject ) )
|
|
{
|
|
return true;
|
|
}
|
|
}
|
|
|
|
return false;
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
void RicReplaceCaseFeature::onActionTriggered( bool isChecked )
|
|
{
|
|
std::vector<RimEclipseResultCase*> selectedEclipseCases;
|
|
caf::SelectionManager::instance()->objectsByType( &selectedEclipseCases );
|
|
|
|
RiaGuiApplication::clearAllSelections();
|
|
|
|
const QStringList fileNames = RicImportGeneralDataFeature::getEclipseFileNamesWithDialog( RiaDefines::ImportFileType::ECLIPSE_RESULT_GRID );
|
|
if ( fileNames.isEmpty() ) return;
|
|
|
|
const QString fileName = fileNames[0];
|
|
|
|
for ( RimEclipseResultCase* selectedCase : selectedEclipseCases )
|
|
{
|
|
selectedCase->setGridFileName( fileName );
|
|
selectedCase->reloadEclipseGridFile();
|
|
|
|
std::vector<RimTimeStepFilter*> timeStepFilter = selectedCase->descendantsIncludingThisOfType<RimTimeStepFilter>();
|
|
if ( timeStepFilter.size() == 1 )
|
|
{
|
|
timeStepFilter[0]->clearFilteredTimeSteps();
|
|
}
|
|
|
|
RimReloadCaseTools::reloadAllEclipseData( selectedCase );
|
|
selectedCase->updateConnectedEditors();
|
|
|
|
// Use the file base name as case user description
|
|
QFileInfo fi( fileName );
|
|
selectedCase->setCaseUserDescription( fi.baseName() );
|
|
|
|
// Find and update attached grid summary cases.
|
|
RimSummaryCaseMainCollection* sumCaseColl = RiaSummaryTools::summaryCaseMainCollection();
|
|
if ( sumCaseColl )
|
|
{
|
|
auto summaryCase = sumCaseColl->findSummaryCaseFromEclipseResultCase( selectedCase );
|
|
if ( summaryCase )
|
|
{
|
|
summaryCase->updateAutoShortName();
|
|
summaryCase->createSummaryReaderInterface();
|
|
summaryCase->createRftReaderInterface();
|
|
|
|
RimSummaryMultiPlotCollection* summaryPlotColl = RiaSummaryTools::summaryMultiPlotCollection();
|
|
for ( RimSummaryMultiPlot* multiPlot : summaryPlotColl->multiPlots() )
|
|
{
|
|
for ( RimSummaryPlot* summaryPlot : multiPlot->summaryPlots() )
|
|
{
|
|
summaryPlot->loadDataAndUpdate();
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
void RicReplaceCaseFeature::setupActionLook( QAction* actionToSetup )
|
|
{
|
|
actionToSetup->setText( "Replace" );
|
|
actionToSetup->setIcon( QIcon( ":/ReplaceCase16x16.png" ) );
|
|
}
|