///////////////////////////////////////////////////////////////////////////////// // // Copyright (C) 2016 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. // ///////////////////////////////////////////////////////////////////////////////// #pragma once #include #include "cafPdmChildArrayField.h" #include "cafPdmChildField.h" #include "cafPdmField.h" #include "cafPdmObject.h" #include "cafPdmPointer.h" #include "cafPdmPtrArrayField.h" #include "cafPdmPtrField.h" #include "RifEclipseSummaryAddress.h" #include "RimSummaryCurve.h" #include "RimSummaryPlot.h" #include "RimSummaryCurveAppearanceCalculator.h" class RimSummaryCase; //================================================================================================== /// /// //================================================================================================== class RicSummaryCurveCreator : public caf::PdmObject { CAF_PDM_HEADER_INIT; private: typedef caf::AppEnum AppearanceTypeAppEnum; class SummaryIdentifierAndField { public: SummaryIdentifierAndField() : m_summaryIdentifier((RifEclipseSummaryAddress::SummaryIdentifierType)0), m_pdmField(nullptr) {} SummaryIdentifierAndField(RifEclipseSummaryAddress::SummaryIdentifierType summaryIdentifier) : m_summaryIdentifier(summaryIdentifier), m_pdmField(new caf::PdmField>()) {} virtual ~SummaryIdentifierAndField() { delete m_pdmField; } RifEclipseSummaryAddress::SummaryIdentifierType summaryIdentifier() const { return m_summaryIdentifier; } caf::PdmField>* pdmField() { return m_pdmField; } private: RifEclipseSummaryAddress::SummaryIdentifierType m_summaryIdentifier; caf::PdmField> * m_pdmField; }; public: RicSummaryCurveCreator(); virtual ~RicSummaryCurveCreator(); RimSummaryPlot* previewPlot() { return m_previewPlot;} void updateFromSummaryPlot(RimSummaryPlot* targetPlot); bool isCloseButtonPressed() const; void clearCloseButton(); private: virtual void fieldChangedByUi(const caf::PdmFieldHandle* changedField, const QVariant& oldValue, const QVariant& newValue); virtual QList calculateValueOptions(const caf::PdmFieldHandle* fieldNeedingOptions, bool* useOptionsOnly); virtual void defineUiOrdering(QString uiConfigName, caf::PdmUiOrdering& uiOrdering) override; virtual void defineEditorAttribute(const caf::PdmFieldHandle* field, QString uiConfigName, caf::PdmUiEditorAttribute* attribute) override; std::set findPossibleSummaryAddresses(const SummaryIdentifierAndField *identifierAndField); std::vector buildControllingFieldList(const SummaryIdentifierAndField *identifierAndField); SummaryIdentifierAndField* lookupIdentifierAndFieldFromFieldHandle(const caf::PdmFieldHandle* pdmFieldHandle); SummaryIdentifierAndField* lookupControllingField(const SummaryIdentifierAndField *dependentField); bool isAddressCompatibleWithControllingFieldSelection(const RifEclipseSummaryAddress &address, const std::vector& identifierAndFieldList); std::set buildAddressListFromSelections(); void buildAddressListForCategoryRecursively(RifEclipseSummaryAddress::SummaryVarCategory category, std::vector::const_iterator identifierAndFieldItr, std::set& addressSet, std::vector>& identifierPath); void loadDataAndUpdatePlot(); void syncPreviewCurvesFromUiSelection(); void updatePreviewCurvesFromCurveDefinitions(const std::set >& curveDefsToAdd, const std::set& curvesToDelete); std::set getAllSummaryCaseNames(); std::set getAllSummaryWellNames(); void populateCurveCreator(const RimSummaryPlot& sourceSummaryPlot); void updateTargetPlot(); static void copyCurveAndAddToPlot(const RimSummaryCurve *curve, RimSummaryPlot *plot, bool forceVisible = false); void resetAllFields(); void updateEditorsConnectedToPreviewPlot(); private: caf::PdmPtrArrayField m_selectedCases; caf::PdmField> m_selectedSummaryCategory; std::map> m_identifierFieldsMap; caf::PdmPtrField m_targetPlot; RimSummaryPlot* m_previewPlot; caf::PdmField m_useAutoAppearanceAssignment; caf::PdmField< AppearanceTypeAppEnum > m_caseAppearanceType; caf::PdmField< AppearanceTypeAppEnum > m_variableAppearanceType; caf::PdmField< AppearanceTypeAppEnum > m_wellAppearanceType; caf::PdmField< AppearanceTypeAppEnum > m_groupAppearanceType; caf::PdmField< AppearanceTypeAppEnum > m_regionAppearanceType; caf::PdmField m_createNewPlot; caf::PdmField m_applyButtonField; caf::PdmField m_closeButtonField; };