///////////////////////////////////////////////////////////////////////////////// // // Copyright (C) 2017- Statoil ASA // // 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 // for more details. // ///////////////////////////////////////////////////////////////////////////////// #include "RicReloadSummaryCaseFeature.h" #include "RiaLogging.h" #include "RiaSummaryTools.h" #include "RicReplaceSummaryCaseFeature.h" #include "RimMainPlotCollection.h" #include "RimObservedDataCollection.h" #include "RimObservedSummaryData.h" #include "RimProject.h" #include "RimSummaryCase.h" #include "RimSummaryCaseCollection.h" #include "RimSummaryCaseMainCollection.h" #include "RimSummaryMultiPlot.h" #include "RimSummaryMultiPlotCollection.h" #include "RimSummaryPlot.h" #include "cafPdmObject.h" #include "cafSelectionManager.h" #include CAF_CMD_SOURCE_INIT( RicReloadSummaryCaseFeature, "RicReloadSummaryCaseFeature" ); //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- bool RicReloadSummaryCaseFeature::isCommandEnabled() { std::vector caseSelection = selectedSummaryCases(); return !caseSelection.empty(); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RicReloadSummaryCaseFeature::onActionTriggered( bool isChecked ) { RimSummaryMultiPlotCollection* summaryPlotColl = RiaSummaryTools::summaryMultiPlotCollection(); std::vector caseSelection = selectedSummaryCases(); for ( RimSummaryCase* summaryCase : caseSelection ) { summaryCase->createSummaryReaderInterface(); summaryCase->createRftReaderInterface(); summaryCase->refreshMetaData(); RicReplaceSummaryCaseFeature::updateRequredCalculatedCurves( summaryCase ); RiaLogging::info( QString( "Reloaded data for %1" ).arg( summaryCase->summaryHeaderFilename() ) ); } for ( RimSummaryMultiPlot* multiPlot : summaryPlotColl->multiPlots() ) { for ( RimSummaryPlot* summaryPlot : multiPlot->summaryPlots() ) { summaryPlot->loadDataAndUpdate(); } } } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RicReloadSummaryCaseFeature::setupActionLook( QAction* actionToSetup ) { actionToSetup->setText( "Reload" ); actionToSetup->setIcon( QIcon( ":/Refresh.svg" ) ); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- std::vector RicReloadSummaryCaseFeature::selectedSummaryCases() { std::vector mainCollectionSelection; caf::SelectionManager::instance()->objectsByType( &mainCollectionSelection ); if ( mainCollectionSelection.size() > 0 ) { return mainCollectionSelection[0]->allSummaryCases(); } std::vector caseSelection; caf::SelectionManager::instance()->objectsByType( &caseSelection ); { std::vector collectionSelection; caf::SelectionManager::instance()->objectsByType( &collectionSelection ); for ( auto collection : collectionSelection ) { std::vector summaryCaseCollection = collection->allSummaryCases(); caseSelection.insert( caseSelection.end(), summaryCaseCollection.begin(), summaryCaseCollection.end() ); } } { std::vector collectionSelection; caf::SelectionManager::instance()->objectsByType( &collectionSelection ); for ( auto collection : collectionSelection ) { std::vector observedCases = collection->allObservedSummaryData(); caseSelection.insert( caseSelection.end(), observedCases.begin(), observedCases.end() ); } } return caseSelection; }