1 // Copyright (C) 2007-2012 CEA/DEN, EDF R&D, OPEN CASCADE
3 // Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
4 // CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
6 // This library is free software; you can redistribute it and/or
7 // modify it under the terms of the GNU Lesser General Public
8 // License as published by the Free Software Foundation; either
9 // version 2.1 of the License.
11 // This library is distributed in the hope that it will be useful,
12 // but WITHOUT ANY WARRANTY; without even the implied warranty of
13 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 // Lesser General Public License for more details.
16 // You should have received a copy of the GNU Lesser General Public
17 // License along with this library; if not, write to the Free Software
18 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
20 // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
22 // GEOM GEOMGUI : GUI for Geometry component
23 // File : GroupGUI.cxx
24 // Author : Sergey ANIKIN, Open CASCADE S.A.S. (sergey.anikin@opencascade.com)
27 #include "GroupGUI_GroupDlg.h"
28 #include "GroupGUI_BooleanDlg.h"
30 #include <GeometryGUI.h>
31 #include "GeometryGUI_Operations.h"
34 #include <GEOMImpl_Types.hxx>
36 #include <SUIT_Session.h>
37 #include <SUIT_Desktop.h>
38 #include <SUIT_MessageBox.h>
39 #include <SalomeApp_Application.h>
40 #include <SalomeApp_Study.h>
41 #include <LightApp_SelectionMgr.h>
43 //=======================================================================
44 // function : GroupGUI()
45 // purpose : Constructor
46 //=======================================================================
47 GroupGUI::GroupGUI (GeometryGUI* parent)
52 //=======================================================================
53 // function : ~GroupGUI()
54 // purpose : Destructor
55 //=======================================================================
61 //=======================================================================
62 // function : OnGUIEvent()
64 //=======================================================================
65 bool GroupGUI::OnGUIEvent (int theCommandID, SUIT_Desktop* parent)
67 SalomeApp_Application* app = getGeometryGUI()->getApp();
68 if (!app) return false;
70 getGeometryGUI()->EmitSignalDeactivateDialog();
74 SalomeApp_Study* appStudy = dynamic_cast<SalomeApp_Study*>(app->activeStudy());
75 if (!appStudy) return false;
76 _PTR(Study) aStudy = appStudy->studyDS();
78 if (aStudy->GetProperties()->IsLocked()) {
79 SUIT_MessageBox::warning(parent, tr("WRN_WARNING"), tr("WRN_STUDY_LOCKED"));
83 switch (theCommandID) {
84 case GEOMOp::OpGroupCreate:
85 case GEOMOp::OpGroupCreatePopup: // CREATE GROUP
86 aDlg = new GroupGUI_GroupDlg (GroupGUI_GroupDlg::CreateGroup, getGeometryGUI(), parent);
88 case GEOMOp::OpGroupEdit: // EDIT GROUP
93 LightApp_SelectionMgr* aSelMgr = app->selectionMgr();
95 aSelMgr->selectedObjects(aList);
97 if (aList.Extent() == 1) {
98 GEOM::GEOM_Object_var anObj =
99 GEOMBase::ConvertIOinGEOMObject(aList.First());
101 if (!CORBA::is_nil(anObj) && anObj->GetType() == GEOM_GROUP) {
102 aDlg = new GroupGUI_GroupDlg (GroupGUI_GroupDlg::EditGroup, getGeometryGUI(), parent);
106 SUIT_MessageBox::warning(parent, tr("WRN_WARNING"), tr("NO_GROUP"));
109 case GEOMOp::OpGroupUnion: // UNION GROUPS
110 aDlg = new GroupGUI_BooleanDlg (GroupGUI_BooleanDlg::UNION, getGeometryGUI(), parent);
112 case GEOMOp::OpGroupIntersect: // INTERSECT GROUPS
113 aDlg = new GroupGUI_BooleanDlg (GroupGUI_BooleanDlg::INTERSECT, getGeometryGUI(), parent);
115 case GEOMOp::OpGroupCut: // CUT GROUPS
116 aDlg = new GroupGUI_BooleanDlg (GroupGUI_BooleanDlg::CUT, getGeometryGUI(), parent);
119 app->putInfo(tr("GEOM_PRP_COMMAND").arg(theCommandID));
124 aDlg->updateGeometry();
125 aDlg->resize(aDlg->minimumSizeHint());
132 //=====================================================================================
134 //=====================================================================================
138 __declspec( dllexport )
140 GEOMGUI* GetLibGUI( GeometryGUI* p )
142 return new GroupGUI( p );