Salome HOME
Fix for bug PAL10407 ( Can't select a mesh in the "create group" dialog box if a...
[modules/smesh.git] / src / SMESHGUI / SMESHGUI_GroupDlg.cxx
1 //  SMESH SMESHGUI : GUI for SMESH component
2 //
3 //  Copyright (C) 2003  OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
4 //  CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS 
5 // 
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. 
10 // 
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. 
15 // 
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 
19 // 
20 //  See http://www.salome-platform.org or email : webmaster.salome@opencascade.org 
21 //
22 //
23 //
24 //  File   : SMESHGUI_GroupDlg.cxx
25 //  Author : Natalia KOPNOVA
26 //  Module : SMESH
27 //  $Header$
28
29 #include "SMESHGUI_GroupDlg.h"
30 #include "SMESHGUI_FilterDlg.h"
31 #include "SMESHGUI_Filter.h"
32
33 #include "SMESHGUI.h"
34 #include "SMESHGUI_Utils.h"
35 #include "SMESHGUI_VTKUtils.h"
36 #include "SMESHGUI_MeshUtils.h"
37 #include "SMESHGUI_GroupUtils.h"
38 #include "SMESHGUI_FilterUtils.h"
39 #include "SMESHGUI_GEOMGenUtils.h"
40
41 #include "SALOMEGUI_QtCatchCorbaException.hxx"
42 #include "SALOME_ListIteratorOfListIO.hxx"
43 #include "VTKViewer_ViewFrame.h"
44 #include "QAD_Application.h"
45 #include "QAD_Desktop.h"
46 #include "QAD_MessageBox.h"
47 #include "QAD_RightFrame.h"
48 #include "utilities.h"
49
50 #include "SMESH_Actor.h"
51
52 #include "GEOMBase.h"
53
54 // QT Includes
55 #include <qbuttongroup.h>
56 #include <qgroupbox.h>
57 #include <qhbox.h>
58 #include <qlabel.h>
59 #include <qlineedit.h>
60 #include <qpushbutton.h>
61 #include <qradiobutton.h>
62 #include <qcheckbox.h>
63 #include <qlayout.h>
64 #include <qlistbox.h>
65 #include <qimage.h>
66 #include <qpixmap.h>
67 #include <qmemarray.h>
68 #include <qwidgetstack.h>
69
70 // STL includes
71 #include <vector>
72 #include <algorithm>
73
74 using namespace std;
75
76 //=================================================================================
77 // class    : SMESHGUI_GroupDlg()
78 // purpose  : 
79 //=================================================================================
80 SMESHGUI_GroupDlg::SMESHGUI_GroupDlg( QWidget* parent, const char* name, SALOME_Selection* theSel,
81                                       SMESH::SMESH_Mesh_ptr theMesh, bool modal, WFlags fl )
82   : QDialog( parent, name, modal, WStyle_Customize | WStyle_NormalBorder | WStyle_Title | WStyle_SysMenu | WDestructiveClose )
83 {
84   if ( !name ) setName( "SMESHGUI_GroupDlg" );
85   initDialog(theSel, true);
86   if (!theMesh->_is_nil())
87     init(theMesh);
88   else {
89     mySelectSubMesh->setEnabled(false);
90     mySelectGroup->setEnabled(false);
91     myGeomGroupBtn->setEnabled(false);
92     myGeomGroupLine->setEnabled(false);
93   }
94   
95   /* Move widget on the botton right corner of main widget */
96   int x, y ;
97   mySMESHGUI->DefineDlgPosition(this, x, y);
98   this->move(x, y);
99 }
100
101 SMESHGUI_GroupDlg::SMESHGUI_GroupDlg( QWidget* parent, const char* name, SALOME_Selection* theSel,
102                                       SMESH::SMESH_Group_ptr theGroup, bool modal, WFlags fl )
103   : QDialog( parent, name, modal, WStyle_Customize | WStyle_NormalBorder | WStyle_Title | WStyle_SysMenu | WDestructiveClose )
104 {
105   if ( !name ) setName( "SMESHGUI_GroupDlg" );
106   initDialog(theSel, false);
107   if (!theGroup->_is_nil())
108     init(theGroup);
109   else {
110     mySelectSubMesh->setEnabled(false);
111     mySelectGroup->setEnabled(false);
112   }
113   
114   /* Move widget on the botton right corner of main widget */
115   int x, y ;
116   mySMESHGUI->DefineDlgPosition(this, x, y);
117   this->move(x, y);
118 }
119
120 void SMESHGUI_GroupDlg::initDialog(SALOME_Selection* theSel, bool create)
121 {
122   myFilterDlg = 0;
123   myCreate = create;
124   myCurrentLineEdit = 0;
125   
126   QPixmap image0(QAD_Desktop::getResourceManager()->loadPixmap( "SMESH",tr("ICON_SELECT")));
127
128   if (create)
129     setCaption( tr( "SMESH_CREATE_GROUP_TITLE"  ) );
130   else
131     setCaption( tr( "SMESH_EDIT_GROUP_TITLE"  ) );
132         
133   setSizeGripEnabled( TRUE );
134
135   QGridLayout* aMainLayout = new QGridLayout(this, 7, 3, 11, 6);
136   
137   /***************************************************************/
138   QLabel* meshGroupLab = new QLabel(this, "mesh/group label");
139   if (create)
140     meshGroupLab->setText(tr("SMESH_MESH"));
141   else
142     meshGroupLab->setText(tr("SMESH_GROUP"));
143   myMeshGroupBtn = new QPushButton(this, "mesh/group button");
144   myMeshGroupBtn->setPixmap(image0);
145   myMeshGroupLine = new QLineEdit(this, "mesh/group line");
146   myMeshGroupLine->setReadOnly(true);
147  
148   /***************************************************************/
149   myTypeGroup = new QButtonGroup(1, Qt::Vertical, this, "Group types");
150   myTypeGroup->setTitle(tr("SMESH_ELEMENTS_TYPE"));
151   myTypeGroup->setExclusive(true);
152
153   QStringList types;
154   types.append(tr("MESH_NODE"));
155   types.append(tr("SMESH_EDGE"));
156   types.append(tr("SMESH_FACE"));
157   types.append(tr("SMESH_VOLUME"));
158   QRadioButton* rb;
159   for (int i = 0; i < types.count(); i++) {
160     rb = new QRadioButton(types[i], myTypeGroup);
161   }
162   myTypeGroup->setEnabled(create);
163   myTypeId = -1;
164     
165   /***************************************************************/
166   QLabel* aName = new QLabel(this, "name label");
167   aName->setText(tr("SMESH_NAME"));
168   aName->setMinimumSize(50,0);
169   myName = new QLineEdit(this, "name");
170
171   /***************************************************************/
172   myGrpTypeGroup = new QButtonGroup(1, Qt::Vertical, this, "Type of group");
173   myGrpTypeGroup->setTitle(tr("SMESH_GROUP_TYPE"));
174   myGrpTypeGroup->setExclusive(true);
175   QRadioButton* rb1 = new QRadioButton( tr("SMESH_GROUP_STANDALONE"), myGrpTypeGroup);
176   QRadioButton* rb2 = new QRadioButton( tr("SMESH_GROUP_GEOMETRY"),   myGrpTypeGroup);
177   myGrpTypeGroup->setEnabled(create);
178   myGrpTypeId = -1;
179
180   /***************************************************************/
181   myWGStack = new QWidgetStack( this, "widget stack");
182   QWidget* wg1 = new QFrame( myWGStack, "first widget" );
183   QWidget* wg2 = new QFrame( myWGStack, "second widget" );
184   
185   /***************************************************************/
186   QGroupBox* aContentBox = new QGroupBox(1, Qt::Horizontal, wg1, "content box");
187   aContentBox->setTitle(tr("SMESH_CONTENT"));
188   QFrame* aContent = new QFrame(aContentBox, "content");
189   QGridLayout* aLayout = new QGridLayout(aContent, 7, 4);
190   aLayout->setSpacing(6);
191   aLayout->setAutoAdd(false);
192
193   QLabel* aLabel = new QLabel(aContent, "elements label");
194   aLabel->setText(tr("SMESH_ID_ELEMENTS"));
195   myElements = new QListBox(aContent, "elements list");
196   myElements->setSelectionMode(QListBox::Extended);
197
198   myFilter = new QPushButton(aContent, "filter");
199   myFilter->setText(tr("SMESH_BUT_FILTER"));
200   QPushButton* aAddBtn = new QPushButton(aContent, "add");
201   aAddBtn->setText(tr("SMESH_BUT_ADD"));
202   QPushButton* aRemoveBtn = new QPushButton(aContent, "remove");
203   aRemoveBtn->setText(tr("SMESH_BUT_REMOVE"));
204   QPushButton* aSortBtn = new QPushButton(aContent, "sort");
205   aSortBtn->setText(tr("SMESH_BUT_SORT"));
206
207   aLayout->addWidget(aLabel, 0, 0);
208   aLayout->addMultiCellWidget(myElements, 1, 6, 0, 0);
209   aLayout->addWidget(myFilter, 1, 2);
210   aLayout->addWidget(aAddBtn, 3, 2);
211   aLayout->addWidget(aRemoveBtn, 4, 2);
212   aLayout->addWidget(aSortBtn, 6, 2);
213
214   aLayout->setColStretch(0, 1);
215   aLayout->addColSpacing(1, 20);
216   aLayout->addColSpacing(3, 20);
217   aLayout->setRowStretch(2, 1);
218   aLayout->setRowStretch(5, 1);
219
220   /***************************************************************/
221   QGroupBox* aSelectBox = new QGroupBox(3, Qt::Horizontal, wg1, "select box");
222   aSelectBox->setTitle(tr("SMESH_SELECT_FROM"));
223   
224   mySelectSubMesh = new QCheckBox(aSelectBox, "submesh checkbox");
225   mySelectSubMesh->setText(tr("SMESH_SUBMESH"));
226   mySelectSubMesh->setMinimumSize(50, 0);
227   mySubMeshBtn = new QPushButton(aSelectBox, "submesh button");
228   mySubMeshBtn->setText("");
229   mySubMeshBtn->setPixmap(image0);
230   mySubMeshLine = new QLineEdit(aSelectBox, "submesh line");
231   mySubMeshLine->setReadOnly(true);
232   onSelectSubMesh(false);
233   
234   mySelectGroup = new QCheckBox(aSelectBox, "group checkbox");
235   mySelectGroup->setText(tr("SMESH_GROUP"));
236   mySelectGroup->setMinimumSize(50, 0);
237   myGroupBtn = new QPushButton(aSelectBox, "group button");
238   myGroupBtn->setText("");
239   myGroupBtn->setPixmap(image0);
240   myGroupLine = new QLineEdit(aSelectBox, "group line");
241   myGroupLine->setReadOnly(true);
242   onSelectGroup(false);
243   
244   /***************************************************************/
245   QGridLayout* wg1Layout = new QGridLayout( wg1, 3, 1, 0, 6 );
246   wg1Layout->addWidget(aContentBox, 0, 0);
247   wg1Layout->addWidget(aSelectBox, 1, 0);
248   wg1Layout->setRowStretch(2, 5);
249
250   /***************************************************************/
251   QLabel* geomObject = new QLabel(wg2, "geometry object label");
252   geomObject->setText(tr("SMESH_OBJECT_GEOM"));
253   myGeomGroupBtn = new QPushButton(wg2, "geometry group button");
254   myGeomGroupBtn->setText("");
255   myGeomGroupBtn->setPixmap(image0);
256   myGeomGroupLine = new QLineEdit(wg2, "geometry group line");
257   myGeomGroupLine->setReadOnly(true); //VSR ???
258   onSelectGeomGroup(false);
259   
260   /***************************************************************/
261   QGridLayout* wg2Layout = new QGridLayout( wg2, 2, 3, 0, 6 );
262   wg2Layout->addWidget(geomObject,     0, 0);
263   wg2Layout->addWidget(myGeomGroupBtn, 0, 1);
264   wg2Layout->addWidget(myGeomGroupLine,0, 2);
265   wg2Layout->setRowStretch(1, 5);
266
267   /***************************************************************/
268   QVBoxLayout* dumb = new QVBoxLayout(myWGStack);
269   dumb->addWidget(wg1);
270   dumb->addWidget(wg2);
271   myWGStack->addWidget( wg1, myGrpTypeGroup->id(rb1) );
272   myWGStack->addWidget( wg2, myGrpTypeGroup->id(rb2) );
273
274   /***************************************************************/
275   QFrame* aButtons = new QFrame(this, "button box");
276   aButtons->setFrameStyle(QFrame::Box | QFrame::Sunken);
277   QHBoxLayout* aBtnLayout = new QHBoxLayout(aButtons, 11, 6);
278   aBtnLayout->setAutoAdd(false);
279
280   QPushButton* aOKBtn = new QPushButton(aButtons, "ok");
281   aOKBtn->setText(tr("SMESH_BUT_OK"));
282   aOKBtn->setAutoDefault(true);
283   aOKBtn->setDefault(true);
284   QPushButton* aApplyBtn = new QPushButton(aButtons, "apply");
285   aApplyBtn->setText(tr("SMESH_BUT_APPLY"));
286   aApplyBtn->setAutoDefault(true);
287   QPushButton* aCloseBtn = new QPushButton(aButtons, "close");
288   aCloseBtn->setText(tr("SMESH_BUT_CLOSE"));
289   aCloseBtn->setAutoDefault(true);
290
291   aBtnLayout->addWidget(aOKBtn);
292   aBtnLayout->addWidget(aApplyBtn);
293   aBtnLayout->addStretch();
294   aBtnLayout->addWidget(aCloseBtn);
295
296   /***************************************************************/
297   aMainLayout->addWidget(meshGroupLab,    0, 0);
298   aMainLayout->addWidget(myMeshGroupBtn,  0, 1);
299   aMainLayout->addWidget(myMeshGroupLine, 0, 2);
300   aMainLayout->addMultiCellWidget(myTypeGroup,    1, 1, 0, 2);
301   aMainLayout->addWidget(aName,      2, 0);
302   aMainLayout->addWidget(myName,     2, 2);
303   aMainLayout->addMultiCellWidget(myGrpTypeGroup, 3, 3, 0, 2);
304   aMainLayout->addMultiCellWidget(myWGStack,      4, 4, 0, 2);
305   aMainLayout->setRowStretch( 5, 5 );
306   aMainLayout->addMultiCellWidget(aButtons,       6, 6, 0, 2);
307
308   /* signals and slots connections */
309   connect(myMeshGroupBtn, SIGNAL(clicked()), this, SLOT(setCurrentSelection()));
310
311   connect(myGrpTypeGroup, SIGNAL(clicked(int)), this, SLOT(onGrpTypeChanged(int)));
312
313   connect(myTypeGroup, SIGNAL(clicked(int)), this, SLOT(onTypeChanged(int)));
314
315   connect(myName, SIGNAL(textChanged(const QString&)), this, SLOT(onNameChanged(const QString&)));
316   connect(myElements, SIGNAL(selectionChanged()), this, SLOT(onListSelectionChanged()));
317
318   connect(myFilter, SIGNAL(clicked()), this, SLOT(setFilters()));
319   connect(aAddBtn, SIGNAL(clicked()), this, SLOT(onAdd()));
320   connect(aRemoveBtn, SIGNAL(clicked()), this, SLOT(onRemove()));
321   connect(aSortBtn, SIGNAL(clicked()), this, SLOT(onSort()));
322
323   connect(mySelectSubMesh, SIGNAL(toggled(bool)), this, SLOT(onSelectSubMesh(bool)));
324   connect(mySelectGroup, SIGNAL(toggled(bool)), this, SLOT(onSelectGroup(bool)));
325   connect(mySubMeshBtn, SIGNAL(clicked()), this, SLOT(setCurrentSelection()));
326   connect(myGroupBtn, SIGNAL(clicked()), this, SLOT(setCurrentSelection()));
327   connect(myGeomGroupBtn, SIGNAL(clicked()), this, SLOT(setCurrentSelection()));
328
329   connect(aOKBtn, SIGNAL(clicked()), this, SLOT(onOK()));
330   connect(aApplyBtn, SIGNAL(clicked()), this, SLOT(onApply()));
331   connect(aCloseBtn, SIGNAL(clicked()), this, SLOT(onClose()));
332
333   /* Init selection */
334   mySelection = theSel;  
335   mySMESHGUI = SMESHGUI::GetSMESHGUI();
336   mySMESHGUI->SetActiveDialogBox(this);
337   mySMESHGUI->SetState(800);
338
339   mySelectionMode = -1;
340   myMeshFilter = new SMESH_TypeFilter(MESH);
341   mySubMeshFilter = new SMESH_TypeFilter(SUBMESH);
342   myGroupFilter = new SMESH_TypeFilter(GROUP);
343
344   connect(mySMESHGUI, SIGNAL(SignalDeactivateActiveDialog()), this, SLOT(onDeactivate()));
345   connect(mySMESHGUI, SIGNAL(SignalCloseAllDialogs()), this, SLOT(onClose()));
346   connect(mySelection, SIGNAL(currentSelectionChanged()), this, SLOT(onObjectSelectionChanged()));
347
348   myGrpTypeGroup->setButton(myGrpTypeGroup->id(rb1)); // VSR !!!
349   onGrpTypeChanged(myGrpTypeGroup->id(rb1)); // VSR!!!
350
351   if (myMesh->_is_nil() )
352     myTypeGroup->setButton(0);
353   
354   updateButtons();
355 }
356
357 //=================================================================================
358 // function : ~SMESHGUI_GroupDlg()
359 // purpose  : Destroys the object and frees any allocated resources
360 //=================================================================================
361 SMESHGUI_GroupDlg::~SMESHGUI_GroupDlg()
362 {
363   // no need to delete child widgets, Qt does it all for us
364   if ( myFilterDlg != 0 )
365   {
366     myFilterDlg->reparent( 0, QPoint() );
367     delete myFilterDlg;
368   }
369 }
370
371
372 //=================================================================================
373 // function : Init()
374 // purpose  :
375 //=================================================================================
376 void SMESHGUI_GroupDlg::init(SMESH::SMESH_Mesh_ptr theMesh)
377 {
378   /* init data from current selection */
379   myMesh = SMESH::SMESH_Mesh::_duplicate(theMesh);
380   myGroup = SMESH::SMESH_Group::_nil();
381   
382   myActor = SMESH::FindActorByObject(myMesh);
383   SMESH::SetPickable(myActor);
384    
385   QString aName = mySelection->firstIObject()->getName();
386   myMeshGroupLine->setText(aName) ;
387   myMeshGroupLine->home( false );
388
389   myCurrentLineEdit = 0;
390
391   myTypeGroup->setButton(0);
392   onTypeChanged(0);
393 }
394
395 //=================================================================================
396 // function : Init()
397 // purpose  :
398 //=================================================================================
399 void SMESHGUI_GroupDlg::init(SMESH::SMESH_Group_ptr theGroup)
400 {
401   myMesh = theGroup->GetMesh();
402   myGroup = SMESH::SMESH_Group::_duplicate(theGroup);
403   
404   myActor = SMESH::FindActorByObject(myMesh);
405   if ( !myActor )
406     myActor = SMESH::FindActorByObject(myGroup);
407   SMESH::SetPickable(myActor);
408   
409   int aType = 0;
410   switch(theGroup->GetType()) {
411   case SMESH::NODE: aType= 0; break;
412   case SMESH::EDGE: aType = 1; break;
413   case SMESH::FACE: aType = 2; break;
414   case SMESH::VOLUME: aType = 3; break;
415   } 
416   
417   myName->setText(myGroup->GetName());
418   myName->home(false);
419   myMeshGroupLine->setText(myGroup->GetName());
420
421   myCurrentLineEdit = 0;
422   myTypeGroup->setButton(aType);
423   myElements->clear();
424   setSelectionMode(aType);
425   myTypeId = aType;
426   
427   myIdList.clear();
428   if (!theGroup->IsEmpty()) {
429     SMESH::long_array_var anElements = myGroup->GetListOfID();
430     int k = anElements->length();
431     for (int i = 0; i < k; i++) {
432       myIdList.append(anElements[i]);
433       myElements->insertItem(QString::number(anElements[i]));
434     }
435     myElements->selectAll(true);
436   }
437 }
438
439
440 //=================================================================================
441 // function : updateButtons()
442 // purpose  : 
443 //=================================================================================
444 void SMESHGUI_GroupDlg::updateButtons()
445 {
446   bool enable; 
447   
448   if (myGrpTypeId == 0)
449     enable = !myName->text().stripWhiteSpace().isEmpty() && myElements->count() > 0;
450   else if (myGrpTypeId == 1)
451     enable = !myName->text().stripWhiteSpace().isEmpty() && !CORBA::is_nil( myGeomGroup );
452   QPushButton* aBtn;
453   aBtn = (QPushButton*) child("ok", "QPushButton");
454   if (aBtn) aBtn->setEnabled(enable);
455   aBtn = (QPushButton*) child("apply", "QPushButton");
456   if (aBtn) aBtn->setEnabled(enable);
457 }
458
459 //=================================================================================
460 // function : onNameChanged()
461 // purpose  : 
462 //=================================================================================
463 void SMESHGUI_GroupDlg::onNameChanged(const QString& text)
464 {
465   updateButtons();
466 }
467
468 //=================================================================================
469 // function : onTypeChanged()
470 // purpose  : Group elements type radio button management
471 //=================================================================================
472 void SMESHGUI_GroupDlg::onTypeChanged(int id)
473 {
474   if (myTypeId != id) {
475     myElements->clear();
476     if (myCurrentLineEdit == 0)
477       setSelectionMode(id);
478   }
479   myTypeId = id;
480 }
481
482 //=================================================================================
483 // function : onGrpTypeChanged()
484 // purpose  : Group type radio button management
485 //=================================================================================
486 void SMESHGUI_GroupDlg::onGrpTypeChanged(int id)
487 {
488   if (myGrpTypeId != id) {
489     myWGStack->raiseWidget( id );
490     onSelectGeomGroup(id == 1);
491   }
492   myGrpTypeId = id;
493 }
494
495 //=================================================================================
496 // function : setSelectionMode()
497 // purpose  : Radio button management
498 //=================================================================================
499 void SMESHGUI_GroupDlg::setSelectionMode(int theMode)
500 {
501   // PAL7314
502   if (myMesh->_is_nil())
503     return;
504   
505   if (mySelectionMode != theMode) {
506     mySelection->ClearIObjects();
507     mySelection->ClearFilters();
508     SMESH::SetPointRepresentation(false);
509     if (theMode < 4) {
510       switch(theMode){
511       case 0:
512         if ( myActor )
513           myActor->SetPointRepresentation(true);
514         else
515           SMESH::SetPointRepresentation(true);
516         QAD_Application::getDesktop()->SetSelectionMode(NodeSelection, true);
517         break;
518       case 1:
519         QAD_Application::getDesktop()->SetSelectionMode(EdgeSelection, true);
520         break;
521       case 2:
522         QAD_Application::getDesktop()->SetSelectionMode(FaceSelection, true);
523         break;
524       default:
525         QAD_Application::getDesktop()->SetSelectionMode(VolumeSelection, true);
526       }
527     }
528     else {
529       QAD_Application::getDesktop()->SetSelectionMode(ActorSelection, true);
530       if (theMode == 4)
531         mySelection->AddFilter(mySubMeshFilter);
532       else if (theMode == 5)
533         mySelection->AddFilter(myGroupFilter);
534       else if (theMode == 6)
535         mySelection->AddFilter(myMeshFilter);
536     }
537     mySelectionMode = theMode;
538   }
539
540
541 //=================================================================================
542 // function : onApply()
543 // purpose  :
544 //=================================================================================
545 bool SMESHGUI_GroupDlg::onApply()
546 {
547   if (mySMESHGUI->ActiveStudyLocked())
548     return false;
549   
550   if ( myGrpTypeId == 0 && !myName->text().stripWhiteSpace().isEmpty() && myElements->count() > 0) {
551     mySelection->ClearIObjects();
552     if (myGroup->_is_nil()) {
553       SMESH::ElementType aType = SMESH::ALL;
554       switch(myTypeId) {
555       case 0: aType = SMESH::NODE; break;
556       case 1: aType = SMESH::EDGE; break;
557       case 2: aType = SMESH::FACE; break;
558       case 3: aType = SMESH::VOLUME; break;
559       }
560       SMESH::long_array_var anIdList = new SMESH::long_array;
561       int i, k = myElements->count();
562       anIdList->length(k);
563       QListBoxItem* anItem;
564       for (i = 0, anItem = myElements->firstItem(); anItem != 0; i++, anItem = anItem->next()) {
565         anIdList[i] = anItem->text().toInt();
566       }
567
568       myGroup = SMESH::AddGroup(myMesh, aType, myName->text());
569       myGroup->Add(anIdList.inout());
570       
571       /* init for next operation */
572       myName->setText("");
573       myElements->clear();
574       myGroup = SMESH::SMESH_Group::_nil();
575     }
576     else {
577       myGroup->SetName(myName->text());
578
579       QValueList<int> aAddList;
580       QValueList<int>::iterator anIt;
581       QListBoxItem* anItem;
582       
583       for (anItem = myElements->firstItem(); anItem != 0; anItem = anItem->next()) {
584         int anId = anItem->text().toInt();
585         if ((anIt = myIdList.find(anId)) == myIdList.end())
586           aAddList.append(anId);
587         else
588           myIdList.remove(anIt);
589       }
590       if (!aAddList.empty()) {
591         SMESH::long_array_var anIdList = new SMESH::long_array;
592         anIdList->length(aAddList.count());
593         int i;
594         for (i = 0, anIt = aAddList.begin(); anIt != aAddList.end(); anIt++, i++)
595           anIdList[i] = *anIt;
596         myGroup->Add(anIdList.inout());
597       }
598       if (!myIdList.empty()) {
599         SMESH::long_array_var anIdList = new SMESH::long_array;
600         anIdList->length(myIdList.count());
601         int i;
602         for (i = 0, anIt = myIdList.begin(); anIt != myIdList.end(); anIt++, i++)
603           anIdList[i] = *anIt;
604         myGroup->Remove(anIdList.inout());
605       }
606       /* init for next operation */
607       myIdList.clear();
608       for (anItem = myElements->firstItem(); anItem != 0; anItem = anItem->next())
609         myIdList.append(anItem->text().toInt());
610     }
611
612     mySMESHGUI->GetActiveStudy()->updateObjBrowser(true);
613     SMESH::UpdateView(); // asv: fix of BUG PAL5515
614     mySelection->ClearIObjects();
615     return true;
616   }
617   else if (myGrpTypeId == 1 && !myName->text().stripWhiteSpace().isEmpty() && !CORBA::is_nil( myGeomGroup ))
618     {
619       SMESH::ElementType aType = SMESH::ALL;
620       switch(myTypeId) {
621       case 0: aType = SMESH::NODE; break;
622       case 1: aType = SMESH::EDGE; break;
623       case 2: aType = SMESH::FACE; break;
624       case 3: aType = SMESH::VOLUME; break;
625       }
626       
627       SALOMEDS::Study_var aStudy = SMESH::GetActiveStudyDocument();
628       GEOM::GEOM_IGroupOperations_var aGroupOp = SMESH::GetGEOMGen()->GetIGroupOperations(aStudy->StudyId());
629       
630       SMESH::SMESH_GroupOnGeom_var aGroupOnGeom = myMesh->CreateGroupFromGEOM(aType, myName->text(),myGeomGroup);
631       
632       mySMESHGUI->GetActiveStudy()->updateObjBrowser(true);
633       mySelection->ClearIObjects();
634       /* init for next operation */
635       myName->setText("");
636       return true;
637     }
638   
639   return false;
640 }
641
642 //=================================================================================
643 // function : onOK()
644 // purpose  :
645 //=================================================================================
646 void SMESHGUI_GroupDlg::onOK()
647 {
648   if ( onApply() )
649     onClose();
650 }
651
652 static bool busy = false;
653 //=================================================================================
654 // function : onListSelectionChanged()
655 // purpose  : Called when selection in element list is changed
656 //=================================================================================
657 void SMESHGUI_GroupDlg::onListSelectionChanged()
658 {
659   //  MESSAGE("SMESHGUI_GroupDlg::onListSelectionChanged(); myActor = " << myActor);
660   if (busy || !myActor) return;
661   busy = true;
662
663   if (myCurrentLineEdit == 0) {
664     mySelection->ClearIObjects();
665     TColStd_MapOfInteger aIndexes;
666     QListBoxItem* anItem;
667     for (anItem = myElements->firstItem(); anItem != 0; anItem = anItem->next()) {
668       if (anItem->isSelected()) {
669         int anId = anItem->text().toInt();
670         aIndexes.Add(anId);
671       }
672     }
673     mySelection->AddOrRemoveIndex(myActor->getIO(), aIndexes, false, false);
674     mySelection->AddIObject(myActor->getIO());
675   }
676   busy = false;
677 }
678
679 //=================================================================================
680 // function : onObjectSelectionChanged()
681 // purpose  : Called when selection in 3D view or ObjectBrowser is changed
682 //=================================================================================
683 void SMESHGUI_GroupDlg::onObjectSelectionChanged()
684 {
685   if (busy || !isEnabled()) return;
686   busy = true;
687
688   int aNbSel = mySelection->IObjectCount();
689   myElements->clearSelection();
690  
691   if (myCurrentLineEdit) {
692     myCurrentLineEdit->setText("") ;
693     QString aString = "";
694     
695     if (myCurrentLineEdit == myMeshGroupLine)
696       {
697         mySelectSubMesh->setEnabled(false);
698         mySelectGroup->setEnabled(false);
699         myGroupLine->setText("");
700         mySubMeshLine->setText("");
701         
702         myGeomGroupBtn->setEnabled(false);
703         myGeomGroupLine->setEnabled(false);
704         myGeomGroupLine->setText("");
705         if (!myCreate)
706           myName->setText("");
707         
708         myElements->clear();
709
710         if(aNbSel != 1)
711           {
712             myGroup = SMESH::SMESH_Group::_nil();
713             myMesh = SMESH::SMESH_Mesh::_nil();
714             busy = false;
715             return;
716           }
717         Handle(SALOME_InteractiveObject) IO = mySelection->firstIObject();
718         
719         if (myCreate)
720           {
721             myMesh = SMESH::IObjectToInterface<SMESH::SMESH_Mesh>(IO);
722             if(myMesh->_is_nil())
723               {
724                 busy = false;
725                 return;
726               }
727             myGroup = SMESH::SMESH_Group::_nil();
728             
729             myActor = SMESH::FindActorByObject(myMesh);
730             SMESH::SetPickable(myActor);
731             
732             aString = mySelection->firstIObject()->getName();
733             myMeshGroupLine->setText(aString) ;
734             myMeshGroupLine->home( false );
735             
736             mySelectSubMesh->setEnabled(true);
737             mySelectGroup->setEnabled(true);
738             myGeomGroupBtn->setEnabled(true);
739             myGeomGroupLine->setEnabled(true);
740             updateButtons();
741           }
742         else
743           {
744             SMESH::SMESH_Group_var aGroup = SMESH::IObjectToInterface<SMESH::SMESH_Group>(IO);
745             if(aGroup->_is_nil())
746               {
747                 busy = false;
748                 return;
749               }
750             busy = false;
751             myCurrentLineEdit = 0;
752             init(aGroup);
753             busy = true;
754             mySelectSubMesh->setEnabled(true);
755             mySelectGroup->setEnabled(true);
756             myGeomGroupBtn->setEnabled(true);
757             myGeomGroupLine->setEnabled(true);
758           }
759         myCurrentLineEdit = 0;
760         busy = false;
761         if (!myCreate)
762           return;
763
764         if (myTypeId == -1)
765           onTypeChanged(0);
766         else
767           {
768             myElements->clear();
769             setSelectionMode(myTypeId);
770           }
771         
772         return;
773       }
774     else if (myCurrentLineEdit == myGeomGroupLine)
775       {
776         
777         if(aNbSel != 1)
778           {
779             myGeomGroup = GEOM::GEOM_Object::_nil();
780             busy = false;
781             return;
782           }
783         
784         Standard_Boolean testResult = Standard_False;
785         myGeomGroup = GEOMBase::ConvertIOinGEOMObject(mySelection->firstIObject(), testResult );
786         
787         // Check if the object is a geometry group
788         if(!testResult || CORBA::is_nil( myGeomGroup ))
789           {
790             myGeomGroup = GEOM::GEOM_Object::_nil();
791             busy = false;
792             return;
793           }
794         // Check if group constructed on the same shape as a mesh or on its child
795         SALOMEDS::Study_var aStudy = SMESH::GetActiveStudyDocument();
796         GEOM::GEOM_IGroupOperations_var anOp = SMESH::GetGEOMGen()->GetIGroupOperations(aStudy->StudyId());
797         // The main shape of the group 
798         GEOM::GEOM_Object_var aGroupMainShape;
799         if( myGeomGroup->GetType() == 37 ) 
800           aGroupMainShape = anOp->GetMainShape( myGeomGroup );
801         else
802           aGroupMainShape = GEOM::GEOM_Object::_duplicate(myGeomGroup);
803         SALOMEDS::SObject_var aGroupMainShapeSO = aStudy->FindObjectIOR( aStudy->ConvertObjectToIOR(aGroupMainShape) );
804         // The mesh SObject
805         SALOMEDS::SObject_var aMeshSO = aStudy->FindObjectIOR( aStudy->ConvertObjectToIOR(myMesh) );
806         if ( aMeshSO->_is_nil() ) {
807           myGeomGroup = GEOM::GEOM_Object::_nil();
808           busy = false;
809           return;
810         }
811         SALOMEDS::SObject_var anObj, aRef;
812         bool isRefOrSubShape = false;
813         if ( aMeshSO->FindSubObject( 1, anObj ) &&  anObj->ReferencedObject( aRef )) {
814           if ( strcmp( aRef->GetID(), aGroupMainShapeSO->GetID() ) == 0 )
815             isRefOrSubShape = true;
816           else
817             {
818               SALOMEDS::SObject_var aFather = aGroupMainShapeSO->GetFather();
819               SALOMEDS::SComponent_var aComponent = aGroupMainShapeSO->GetFatherComponent();
820               while ( !isRefOrSubShape && strcmp( aFather->GetID(), aComponent->GetID() ) != 0 )
821                 {
822                   if (strcmp( aRef->GetID(), aFather->GetID() ) == 0)
823                     isRefOrSubShape = true;
824                   else
825                     aFather = aFather->GetFather();
826                 }
827             }
828         }
829         if ( !isRefOrSubShape ) 
830           {
831             myGeomGroup = GEOM::GEOM_Object::_nil();
832             busy = false;
833             return;
834           }
835       }
836     
837     if (aNbSel >= 1) {
838       if (aNbSel > 1) {
839         if (myCurrentLineEdit == mySubMeshLine)
840           aString = tr("SMESH_SUBMESH_SELECTED").arg(aNbSel);
841         else if (myCurrentLineEdit == myGroupLine || myCurrentLineEdit == myGeomGroupLine)
842           aString = tr("SMESH_GROUP_SELECTED").arg(aNbSel);
843       }
844       else {
845         aString = mySelection->firstIObject()->getName();
846       }
847     }
848     
849     myCurrentLineEdit->setText(aString) ;
850     myCurrentLineEdit->home( false );
851     
852     updateButtons();
853   }
854   else {
855     if (aNbSel == 1) {
856       QString aListStr = "";
857       int aNbItems = 0;
858       if (myTypeId == 0) {
859         aNbItems = SMESH::GetNameOfSelectedNodes(mySelection, aListStr);
860       }
861       else {
862         aNbItems = SMESH::GetNameOfSelectedElements(mySelection, aListStr);
863       }
864       if (aNbItems > 0) {
865         QStringList anElements = QStringList::split(" ", aListStr);
866         QListBoxItem* anItem = 0;
867         for (QStringList::iterator it = anElements.begin(); it != anElements.end(); ++it) {
868           anItem = myElements->findItem(*it, Qt::ExactMatch);
869           if (anItem) myElements->setSelected(anItem, true);
870         }
871       }
872     }
873   }
874   
875   if ( !myActor ) {
876     if ( !myGroup->_is_nil() )
877       myActor = SMESH::FindActorByObject(myGroup);
878     else
879       myActor = SMESH::FindActorByObject(myMesh);
880   }
881   
882   busy = false;
883 }
884
885
886 //=================================================================================
887 // function : onSelectSubMesh()
888 // purpose  : Called when selection in 3D view or ObjectBrowser is changed
889 //=================================================================================
890 void SMESHGUI_GroupDlg::onSelectSubMesh(bool on)
891 {
892   if (on) {
893     if (mySelectGroup->isChecked()) {
894       mySelectGroup->setChecked(false);
895     } 
896     //VSR: else if (mySelectGeomGroup->isChecked()) {
897     //VSR:   mySelectGeomGroup->setChecked(false);
898     //VSR: }
899     myCurrentLineEdit = mySubMeshLine;
900     setSelectionMode(4);
901   }
902   else {
903     mySubMeshLine->setText("");
904     myCurrentLineEdit = 0;
905     if (myTypeId != -1)
906       setSelectionMode(myTypeId);
907   }
908   mySubMeshBtn->setEnabled(on);
909   mySubMeshLine->setEnabled(on);
910 }
911
912
913 //=================================================================================
914 // function : (onSelectGroup)
915 // purpose  : Called when selection in 3D view or ObjectBrowser is changed
916 //=================================================================================
917 void SMESHGUI_GroupDlg::onSelectGroup(bool on)
918 {
919   if (on) {
920     if (mySelectSubMesh->isChecked()) {
921       mySelectSubMesh->setChecked(false);
922     }
923     myCurrentLineEdit = myGroupLine;
924     setSelectionMode(5);
925   }
926   else {
927     myGroupLine->setText("");
928     myCurrentLineEdit = 0;
929     if (myTypeId != -1)
930       setSelectionMode(myTypeId);
931   }
932   myGroupBtn->setEnabled(on);
933   myGroupLine->setEnabled(on);
934 }
935
936
937 //=================================================================================
938 // function : (onSelectGeomGroup)
939 // purpose  : Called when selection in 3D view or ObjectBrowser is changed
940 //=================================================================================
941 void SMESHGUI_GroupDlg::onSelectGeomGroup(bool on)
942 {
943   if (on) {
944     if (mySelectSubMesh->isChecked()) {
945       mySelectSubMesh->setChecked(false);
946     }
947     else if (mySelectGroup->isChecked()) {
948       mySelectGroup->setChecked(false);
949     }
950     myCurrentLineEdit = myGeomGroupLine;
951     setSelectionMode(7);
952   }
953   else {
954     myGeomGroupLine->setText("");
955     myCurrentLineEdit = 0;
956     if (myTypeId != -1)
957       setSelectionMode(myTypeId);
958   }
959 }
960
961
962 //=================================================================================
963 // function : setCurrentSelection()
964 // purpose  :
965 //=================================================================================
966 void SMESHGUI_GroupDlg::setCurrentSelection()
967 {
968   QPushButton* send = (QPushButton*)sender();
969   myCurrentLineEdit = 0;
970   if (send == myMeshGroupBtn) {
971     myCurrentLineEdit = myMeshGroupLine;
972     if (myCreate)
973       setSelectionMode(6);
974     else
975       setSelectionMode(5);
976     onObjectSelectionChanged();
977   }
978   else if (send == mySubMeshBtn) {
979     myCurrentLineEdit = mySubMeshLine;
980     onObjectSelectionChanged();
981   }
982   else if (send == myGroupBtn) {
983     myCurrentLineEdit = myGroupLine;
984     onObjectSelectionChanged();
985   }
986   else if (send == myGeomGroupBtn) {
987     myCurrentLineEdit = myGeomGroupLine;
988     setSelectionMode(7);
989     onObjectSelectionChanged();
990   }
991 }
992
993
994 //=================================================================================
995 // function : setFilters()
996 // purpose  : SLOT. Called when "Filter" button pressed. 
997 //=================================================================================
998 void SMESHGUI_GroupDlg::setFilters()
999 {
1000   SMESH::ElementType aType = SMESH::ALL;
1001   switch ( myTypeId )
1002   {
1003     case 0 : aType = SMESH::NODE; break;
1004     case 1 : aType = SMESH::EDGE; break;
1005     case 2 : aType = SMESH::FACE; break;
1006     case 3 : aType = SMESH::VOLUME; break;
1007     default: return;
1008   }
1009
1010   if ( myFilterDlg == 0 )
1011   {
1012     myFilterDlg = new SMESHGUI_FilterDlg( (QWidget*)parent(), aType );
1013     connect( myFilterDlg, SIGNAL( Accepted() ), SLOT( onFilterAccepted() ) );
1014   }
1015   else
1016     myFilterDlg->Init( aType );
1017
1018   myFilterDlg->SetSelection( mySelection );
1019   myFilterDlg->SetMesh( myMesh );
1020   myFilterDlg->SetSourceWg( myElements );
1021
1022   myFilterDlg->show();
1023 }
1024
1025 //=================================================================================
1026 // function : onFilterAccepted()
1027 // purpose  : SLOT. Called when Filter dlg closed with OK button.
1028 //            Uncheck "Select submesh" and "Select group" checkboxes
1029 //=================================================================================
1030 void SMESHGUI_GroupDlg::onFilterAccepted()
1031 {
1032   if ( mySelectSubMesh->isChecked() || mySelectGroup->isChecked() )
1033   {
1034     mySelectionMode = myTypeId;
1035     mySelectSubMesh->setChecked( false );
1036     mySelectGroup->setChecked( false );
1037   }
1038 }
1039
1040 //=================================================================================
1041 // function : onAdd()
1042 // purpose  :
1043 //=================================================================================
1044 void SMESHGUI_GroupDlg::onAdd()
1045 {
1046   int aNbSel = mySelection->IObjectCount();
1047   if (aNbSel == 0 || !myActor || myMesh->_is_nil()) return;
1048
1049   busy = true;
1050
1051   SMESH::ElementType aType = SMESH::ALL;
1052   switch(myTypeId) {
1053   case 0: aType = SMESH::NODE; break;
1054   case 1: aType = SMESH::EDGE; break;
1055   case 2: aType = SMESH::FACE; break;
1056   case 3: aType = SMESH::VOLUME; break;
1057   }
1058
1059   if (myCurrentLineEdit == 0) {
1060     //if (aNbSel != 1) { busy = false; return; }
1061     QString aListStr = "";
1062     int aNbItems = 0;
1063     if (myTypeId == 0) {
1064       aNbItems = SMESH::GetNameOfSelectedNodes(mySelection, myActor->getIO(), aListStr);
1065     }
1066     else {
1067       aNbItems = SMESH::GetNameOfSelectedElements(mySelection, myActor->getIO(), aListStr);
1068     }
1069     if (aNbItems > 0) {
1070       QStringList anElements = QStringList::split(" ", aListStr);
1071       QListBoxItem* anItem = 0;
1072       for (QStringList::iterator it = anElements.begin(); it != anElements.end(); ++it) {
1073         anItem = myElements->findItem(*it, Qt::ExactMatch);
1074         if (!anItem) {
1075           anItem = new QListBoxText(*it);
1076           myElements->insertItem(anItem);
1077         }
1078         myElements->setSelected(anItem, true);
1079       }
1080     }
1081   }
1082   else if (myCurrentLineEdit == mySubMeshLine) {
1083     SALOME_ListIteratorOfListIO anIt(mySelection->StoredIObjects());
1084     for (; anIt.More(); anIt.Next()) {
1085       SMESH::SMESH_subMesh_var aSubMesh = SMESH::IObjectToInterface<SMESH::SMESH_subMesh>(anIt.Value());
1086       if (!aSubMesh->_is_nil()) {
1087         // check if mesh is the same
1088         if (aSubMesh->GetFather()->GetId() == myMesh->GetId()) {
1089           try {
1090             SMESH::long_array_var anElements = aSubMesh->GetElementsByType ( aType );
1091             int k = anElements->length();
1092             QListBoxItem* anItem = 0;
1093             for (int i = 0; i < k; i++) {
1094               QString aText = QString::number(anElements[i]);
1095               anItem = myElements->findItem(aText, Qt::ExactMatch);
1096               if (!anItem) {
1097                 anItem = new QListBoxText(aText);
1098                 myElements->insertItem(anItem);
1099               }
1100               myElements->setSelected(anItem, true);
1101             }
1102           }
1103           catch (const SALOME::SALOME_Exception& ex) {
1104             QtCatchCorbaException(ex);
1105           }
1106         }
1107       }
1108     }
1109     mySelectSubMesh->setChecked(false);
1110     busy = false;
1111     onListSelectionChanged();
1112   }
1113   else if (myCurrentLineEdit == myGroupLine) {
1114     SALOME_ListIteratorOfListIO anIt(mySelection->StoredIObjects());
1115     for (; anIt.More(); anIt.Next()) {
1116       SMESH::SMESH_Group_var aGroup = SMESH::IObjectToInterface<SMESH::SMESH_Group>(anIt.Value());
1117       if (!aGroup->_is_nil()) {
1118         // check if mesh is the same
1119         if (aGroup->GetType() == aType && aGroup->GetMesh()->GetId() == myMesh->GetId()) {
1120           SMESH::long_array_var anElements = aGroup->GetListOfID();
1121           int k = anElements->length();
1122           QListBoxItem* anItem = 0;
1123           for (int i = 0; i < k; i++) {
1124             QString aText = QString::number(anElements[i]);
1125             anItem = myElements->findItem(aText, Qt::ExactMatch);
1126             if (!anItem) {
1127               anItem = new QListBoxText(aText);
1128               myElements->insertItem(anItem);
1129             }
1130             myElements->setSelected(anItem, true);
1131           }
1132         }
1133       }
1134     }
1135     mySelectGroup->setChecked(false);
1136     busy = false;
1137     onListSelectionChanged();
1138   }
1139   else if (myCurrentLineEdit == myGeomGroupLine && !CORBA::is_nil(myGeomGroup)) {
1140     
1141     SALOMEDS::Study_var aStudy = SMESH::GetActiveStudyDocument();
1142     GEOM::GEOM_IGroupOperations_var aGroupOp = SMESH::GetGEOMGen()->GetIGroupOperations(aStudy->StudyId());
1143     
1144     SMESH::ElementType aGroupType = SMESH::ALL;
1145     switch(aGroupOp->GetType(myGeomGroup)) {
1146     case 7: aGroupType = SMESH::NODE; break;
1147     case 6: aGroupType = SMESH::EDGE; break;
1148     case 4: aGroupType = SMESH::FACE; break;
1149     case 2: aGroupType = SMESH::VOLUME; break;
1150     default: return;
1151     }
1152     
1153     if (aGroupType == aType) {
1154       SALOMEDS::SObject_var aGroupSO = aStudy->FindObjectIOR( aStudy->ConvertObjectToIOR(myGeomGroup) );
1155       // Construct filter
1156       SMESH::FilterManager_var aFilterMgr = SMESH::GetFilterManager();
1157       SMESH::Filter_var aFilter = aFilterMgr->CreateFilter();
1158       SMESH::BelongToGeom_var aBelongToGeom = aFilterMgr->CreateBelongToGeom();;
1159       aBelongToGeom->SetGeom(myGeomGroup);
1160       aBelongToGeom->SetShapeName(aGroupSO->GetName());
1161       aBelongToGeom->SetElementType(aType);
1162       aFilter->SetPredicate( aBelongToGeom );
1163       
1164       SMESH::long_array_var anElements = aFilter->GetElementsId( myMesh );
1165       
1166       int k = anElements->length();
1167       QListBoxItem* anItem = 0;
1168       for (int i = 0; i < k; i++) {
1169         QString aText = QString::number(anElements[i]);
1170         anItem = myElements->findItem(aText, Qt::ExactMatch);
1171         if (!anItem) {
1172           anItem = new QListBoxText(aText);
1173           myElements->insertItem(anItem);
1174         }
1175         myElements->setSelected(anItem, true);
1176       }
1177     }
1178     
1179     //VSR: mySelectGeomGroup->setChecked(false);
1180     busy = false;
1181     onListSelectionChanged();
1182   }
1183   busy = false;
1184   //  mySelection->ClearIObjects();
1185   updateButtons();
1186 }
1187
1188 //=================================================================================
1189 // function : onRemove()
1190 // purpose  :
1191 //=================================================================================
1192 void SMESHGUI_GroupDlg::onRemove()
1193 {
1194   busy = true;
1195   if (myCurrentLineEdit == 0) {
1196     for (int i = myElements->count(); i > 0; i--) {
1197       if (myElements->isSelected(i-1)) {
1198         myElements->removeItem(i-1);
1199       }
1200     }
1201   }
1202   else {
1203     int aNbSel = mySelection->IObjectCount();
1204     if (aNbSel == 0) { busy = false; return; }
1205     
1206     SMESH::ElementType aType = SMESH::ALL;
1207     switch(myTypeId) {
1208     case 0: aType = SMESH::NODE; break;
1209     case 1: aType = SMESH::EDGE; break;
1210     case 2: aType = SMESH::FACE; break;
1211     case 3: aType = SMESH::VOLUME; break;
1212     }
1213
1214     if (myCurrentLineEdit == mySubMeshLine) {
1215       SALOME_ListIteratorOfListIO anIt(mySelection->StoredIObjects());
1216       for (; anIt.More(); anIt.Next()) {
1217         SMESH::SMESH_subMesh_var aSubMesh = SMESH::IObjectToInterface<SMESH::SMESH_subMesh>(anIt.Value());
1218         if (!aSubMesh->_is_nil()) {
1219           // check if mesh is the same
1220           if (aSubMesh->GetFather()->GetId() == myMesh->GetId()) {
1221             if (aType == SMESH::NODE) {
1222               try {
1223                 SMESH::long_array_var anElements = aSubMesh->GetNodesId();
1224                 int k = anElements->length();
1225                 QListBoxItem* anItem = 0;
1226                 for (int i = 0; i < k; i++) {
1227                   anItem = myElements->findItem(QString::number(anElements[i]), Qt::ExactMatch);
1228                   if (anItem) delete anItem;
1229                 }
1230               }
1231               catch (const SALOME::SALOME_Exception& ex) {
1232                 QtCatchCorbaException(ex);
1233               }
1234             }
1235             else {
1236               try {
1237                 SMESH::long_array_var anElements = aSubMesh->GetElementsId();
1238                 int k = anElements->length();
1239                 QListBoxItem* anItem = 0;
1240                 for (int i = 0; i < k; i++) {
1241                   anItem = myElements->findItem(QString::number(anElements[i]), Qt::ExactMatch);
1242                   if (anItem) delete anItem;
1243                 }
1244               }
1245               catch (const SALOME::SALOME_Exception& ex) {
1246                 QtCatchCorbaException(ex);
1247               }
1248             }
1249           }
1250         }
1251       }
1252     }
1253     else if (myCurrentLineEdit == myGroupLine) {
1254       Standard_Boolean aRes;
1255       SALOME_ListIteratorOfListIO anIt(mySelection->StoredIObjects());
1256       for (; anIt.More(); anIt.Next()) {
1257         SMESH::SMESH_Group_var aGroup = SMESH::IObjectToInterface<SMESH::SMESH_Group>(anIt.Value());
1258         if (aRes && !aGroup->_is_nil()) {
1259           // check if mesh is the same
1260           if (aGroup->GetType() == aType && aGroup->GetMesh()->GetId() == myMesh->GetId()) {
1261             SMESH::long_array_var anElements = aGroup->GetListOfID();
1262             int k = anElements->length();
1263             QListBoxItem* anItem = 0;
1264             for (int i = 0; i < k; i++) {
1265               anItem = myElements->findItem(QString::number(anElements[i]), Qt::ExactMatch);
1266               if (anItem) delete anItem;
1267             }
1268           }
1269         }
1270       }
1271     }
1272   }
1273   busy = false;
1274   updateButtons();
1275 }
1276
1277 //=================================================================================
1278 // function : onSort()
1279 // purpose  :
1280 //=================================================================================
1281 void SMESHGUI_GroupDlg::onSort()
1282 {
1283   // PAL5412: sorts items in ascending by "string" value
1284   // myElements->sort(true);
1285   // myElements->update();
1286   int i, k = myElements->count();
1287   if (k > 0) {
1288     busy = true;
1289     QStringList aSelected;
1290     std::vector<int> anArray(k);
1291     //    QMemArray<int> anArray(k);
1292     QListBoxItem* anItem;
1293     // fill the array
1294     for (anItem = myElements->firstItem(), i = 0; anItem != 0; anItem = anItem->next(), i++) {
1295       anArray[i] = anItem->text().toInt();
1296       if (anItem->isSelected()) 
1297         aSelected.append(anItem->text());
1298     }
1299     // sort & update list
1300     std::sort(anArray.begin(), anArray.end());
1301     //    anArray.sort();
1302     myElements->clear();
1303     for (i = 0; i < k; i++) {
1304       myElements->insertItem(QString::number(anArray[i]));
1305     }
1306     for (QStringList::iterator it = aSelected.begin(); it != aSelected.end(); ++it) {
1307       anItem = myElements->findItem(*it, Qt::ExactMatch);
1308       if (anItem) myElements->setSelected(anItem, true);
1309     }
1310     busy = false;
1311   }
1312 }
1313
1314 //=================================================================================
1315 // function : closeEvent()
1316 // purpose  :
1317 //=================================================================================
1318 void SMESHGUI_GroupDlg::closeEvent( QCloseEvent* e )
1319 {
1320   onClose();
1321 }
1322
1323 //=======================================================================
1324 // name    : SMESHGUI_GroupDlg::onClose
1325 // Purpose : SLOT called when "Close" button pressed. Close dialog
1326 //=======================================================================
1327 void SMESHGUI_GroupDlg::onClose()
1328 {
1329   QAD_StudyFrame* aStudyFrame = mySMESHGUI->GetActiveStudy()->getActiveStudyFrame();
1330   if (aStudyFrame->getTypeView() == VIEW_VTK) {
1331     SMESH::RemoveFilters(); // PAL6938 -- clean all mesh entity filters
1332     SMESH::SetPointRepresentation(false);
1333     SMESH::SetPickable();
1334   }
1335   
1336   mySelection->ClearIObjects();
1337   QAD_Application::getDesktop()->SetSelectionMode(ActorSelection);
1338   mySelection->ClearFilters();
1339   mySMESHGUI->ResetState();
1340
1341   reject();
1342 }
1343
1344 //=======================================================================
1345 // name    : SMESHGUI_GroupDlg::onDeactivate
1346 // Purpose : SLOT called when dialog must be deativated
1347 //=======================================================================
1348 void SMESHGUI_GroupDlg::onDeactivate()
1349 {
1350   mySMESHGUI->ResetState();
1351   setEnabled( false );
1352 }
1353
1354 //=======================================================================
1355 // name    : SMESHGUI_GroupDlg::enterEvent
1356 // Purpose : Event filter
1357 //=======================================================================
1358 void SMESHGUI_GroupDlg::enterEvent( QEvent* )
1359 {
1360   if ( !isEnabled() ) {
1361     SMESHGUI::GetSMESHGUI()->EmitSignalDeactivateDialog();
1362     setEnabled( true );
1363     mySelectionMode = -1;
1364     setSelectionMode( myTypeId );
1365     mySMESHGUI->SetActiveDialogBox( (QDialog*)this ) ;
1366     mySMESHGUI->SetState(800);
1367   }
1368 }
1369
1370 //=======================================================================
1371 //function : hideEvent
1372 //purpose  : caused by ESC key
1373 //=======================================================================
1374
1375 void SMESHGUI_GroupDlg::hideEvent ( QHideEvent * e )
1376 {
1377   if ( !isMinimized() )
1378     onClose();
1379 }