///////////////////////////////////////////////////////////////////////////////// // // Copyright (C) 2018- 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 // for more details. // ///////////////////////////////////////////////////////////////////////////////// #include "RicPasteStimPlanFractureFeature.h" #include "OperationsUsingObjReferences/RicPasteFeatureImpl.h" #include "RicNewEllipseFractureTemplateFeature.h" #include "RimFractureTemplateCollection.h" #include "RimStimPlanFractureTemplate.h" #include "cafPdmObjectGroup.h" #include "cafSelectionManager.h" #include #include CAF_CMD_SOURCE_INIT(RicPasteStimPlanFractureFeature, "RicPasteStimPlanFractureFeature"); //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- bool RicPasteStimPlanFractureFeature::isCommandEnabled() { caf::PdmObjectGroup objectGroup; RicPasteFeatureImpl::findObjectsFromClipboardRefs(&objectGroup); std::vector> typedObjects; objectGroup.objectsByType(&typedObjects); if (typedObjects.size() == 0) { return false; } if (fractureTemplateCollection()) { return true; } return false; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RicPasteStimPlanFractureFeature::onActionTriggered(bool isChecked) { auto fractureTemplateColl = fractureTemplateCollection(); if (!fractureTemplateColl) return; caf::PdmObjectGroup objectGroup; RicPasteFeatureImpl::findObjectsFromClipboardRefs(&objectGroup); std::vector> typedObjects; objectGroup.objectsByType(&typedObjects); for (const auto& source : typedObjects) { auto copyOfStimPlanTemplate = dynamic_cast( source->xmlCapability()->copyByXmlSerialization(caf::PdmDefaultObjectFactory::instance())); fractureTemplateColl->addFractureTemplate(copyOfStimPlanTemplate); RicNewEllipseFractureTemplateFeature::selectFractureTemplateAndUpdate(copyOfStimPlanTemplate); } return; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RicPasteStimPlanFractureFeature::setupActionLook(QAction* actionToSetup) { actionToSetup->setText("Paste (StimPlan Fracture)"); RicPasteFeatureImpl::setIconAndShortcuts(actionToSetup); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- RimFractureTemplateCollection* RicPasteStimPlanFractureFeature::fractureTemplateCollection() { RimFractureTemplateCollection* fractureTemplateColl = nullptr; auto destinationObject = dynamic_cast(caf::SelectionManager::instance()->selectedItem()); if (destinationObject) { destinationObject->firstAncestorOrThisOfType(fractureTemplateColl); } return fractureTemplateColl; }