ResInsight/ApplicationLibCode/Commands/RicImportVfpDataFeature.cpp

95 lines
3.5 KiB
C++
Raw Normal View History

/////////////////////////////////////////////////////////////////////////////////
//
// Copyright (C) 2020 Equinor 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 <http://www.gnu.org/licenses/gpl.html>
// for more details.
//
/////////////////////////////////////////////////////////////////////////////////
2024-05-07 01:46:54 -05:00
#include "RicImportVfpDataFeature.h"
#include "RiaApplication.h"
#include "RiaGuiApplication.h"
#include "RimMainPlotCollection.h"
#include "VerticalFlowPerformance/RimCustomVfpPlot.h"
#include "VerticalFlowPerformance/RimVfpDataCollection.h"
#include "VerticalFlowPerformance/RimVfpPlotCollection.h"
#include "RiuFileDialogTools.h"
#include "RiuPlotMainWindow.h"
#include "RiuPlotMainWindowTools.h"
#include "cafSelectionManagerTools.h"
#include <QAction>
#include <QFileInfo>
2024-05-07 01:46:54 -05:00
CAF_CMD_SOURCE_INIT( RicImportVfpDataFeature, "RicImportVfpDataFeature" );
//--------------------------------------------------------------------------------------------------
///
//--------------------------------------------------------------------------------------------------
2024-05-07 01:46:54 -05:00
void RicImportVfpDataFeature::onActionTriggered( bool isChecked )
{
RimVfpPlotCollection* vfpPlotColl = RimMainPlotCollection::current()->vfpPlotCollection();
if ( !vfpPlotColl ) return;
RiaApplication* app = RiaGuiApplication::instance();
RiuPlotMainWindow* mpw = RiaGuiApplication::instance()->mainPlotWindow();
const QString vfpDataKey = "VFP_DATA";
QString defaultDir = app->lastUsedDialogDirectory( vfpDataKey );
2024-05-07 01:46:54 -05:00
QString vfpTextFileFilter = "VFP Text Files (*.ecl *.vfp)";
QString simulatorInputFilter = "Simulator Input Files (*.data)";
QString allFilters = vfpTextFileFilter + ";;" + simulatorInputFilter + ";;" + "All Files (*.*)";
QString selectedFilter = simulatorInputFilter;
QVariant userData = this->userData();
if ( !userData.isNull() && userData.canConvert<bool>() )
{
bool isVfpFiles = userData.toBool();
if ( isVfpFiles ) selectedFilter = vfpTextFileFilter;
}
QStringList fileNames = RiuFileDialogTools::getOpenFileNames( mpw, "Import VFP Files", defaultDir, allFilters, &selectedFilter );
if ( fileNames.isEmpty() ) return;
app->setLastUsedDialogDirectory( vfpDataKey, QFileInfo( fileNames.last() ).absolutePath() );
auto vfpDataColl = RimVfpDataCollection::instance();
for ( const auto& fileName : fileNames )
{
auto vfpDataSource = vfpDataColl->appendTableDataObject( fileName );
auto firstPlot = vfpPlotColl->createAndAppendPlots( vfpDataSource, {} );
vfpDataColl->updateAllRequiredEditors();
RiuPlotMainWindowTools::onObjectAppended( firstPlot, firstPlot );
}
vfpPlotColl->updateAllRequiredEditors();
}
//--------------------------------------------------------------------------------------------------
///
//--------------------------------------------------------------------------------------------------
2024-05-07 01:46:54 -05:00
void RicImportVfpDataFeature::setupActionLook( QAction* actionToSetup )
{
2024-05-07 01:46:54 -05:00
actionToSetup->setText( "Import VFP Data" );
2021-04-21 06:12:26 -05:00
actionToSetup->setIcon( QIcon( ":/VfpPlot.svg" ) );
}