///////////////////////////////////////////////////////////////////////////////// // // 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. // ///////////////////////////////////////////////////////////////////////////////// #pragma once #include "cafPdmObject.h" #include "cafPdmField.h" #include "cafPdmChildField.h" class RimFishbonesCollection; class RimPerforationCollection; class RimWellPathFractureCollection; class RimWellPathComponentInterface; class RimWellPathValve; //================================================================================================== /// /// //================================================================================================== class RimWellPathCompletions : public caf::PdmObject { CAF_PDM_HEADER_INIT; enum WellType {OIL, GAS, WATER, LIQUID}; typedef caf::AppEnum WellTypeEnum; enum GasInflowEquation {STANDARD_EQ, RUSSELL_GOODRICH, DRY_GAS_PSEUDO_PRESSURE, GENERALIZED_PSEUDO_PRESSURE }; typedef caf::AppEnum GasInflowEnum; enum AutomaticWellShutIn {ISOLATE_FROM_FORMATION, STOP_ABOVE_FORMATION }; typedef caf::AppEnum AutomaticWellShutInEnum; enum HydrostaticDensity { SEGMENTED, AVERAGED }; typedef caf::AppEnum HydrostaticDensityEnum; public: RimWellPathCompletions(); RimFishbonesCollection* fishbonesCollection() const; RimPerforationCollection* perforationCollection() const; RimWellPathFractureCollection* fractureCollection() const; std::vector valves() const; std::vector allCompletions() const; void setWellNameForExport(const QString& name); void updateWellPathNameHasChanged(const QString& newWellPathName, const QString& previousWellPathName); QString wellNameForExport() const; QString wellGroupNameForExport() const; QString referenceDepthForExport() const; QString wellTypeNameForExport() const; bool hasCompletions() const; QString drainageRadiusForExport() const; QString gasInflowEquationForExport() const; QString automaticWellShutInForExport() const; QString allowWellCrossFlowForExport() const; QString wellBoreFluidPVTForExport() const; QString hydrostaticDensityForExport() const; QString fluidInPlaceRegionForExport() const; void setUnitSystemSpecificDefaults(); static QRegExp wellNameForExportRegExp(); protected: void defineUiOrdering(QString uiConfigName, caf::PdmUiOrdering& uiOrdering) override; void defineUiTreeOrdering(caf::PdmUiTreeOrdering& uiTreeOrdering, QString uiConfigName) override; void fieldChangedByUi(const caf::PdmFieldHandle* changedField, const QVariant& oldValue, const QVariant& newValue) override; void defineEditorAttribute(const caf::PdmFieldHandle* field, QString uiConfigName, caf::PdmUiEditorAttribute* attribute) override; private: QString formatStringForExport(const QString& text, const QString& defaultText = "") const; private: caf::PdmChildField m_fishbonesCollection; caf::PdmChildField m_perforationCollection; caf::PdmChildField m_fractureCollection; caf::PdmField m_wellNameForExport; caf::PdmField m_wellGroupName; caf::PdmField m_referenceDepth; caf::PdmField m_preferredFluidPhase; caf::PdmField m_drainageRadiusForPI; caf::PdmField m_gasInflowEquation; caf::PdmField m_automaticWellShutIn; caf::PdmField m_allowWellCrossFlow; caf::PdmField m_wellBoreFluidPVTTable; caf::PdmField m_hydrostaticDensity; caf::PdmField m_fluidInPlaceRegion; };