Salome HOME
Copyright update 2022
[modules/paravis.git] / src / PVGUI / PVGUI_Module_widgets.cxx
index 8da50c9eeba5f624afcf165ef5b89bf2c9c29196..7f65637000c279dc3c479844ffd04d92550dd48b 100644 (file)
@@ -1,6 +1,6 @@
 // PARAVIS : ParaView wrapper SALOME module
 //
-// Copyright (C) 2010-2016  CEA/DEN, EDF R&D
+// Copyright (C) 2010-2022  CEA/DEN, EDF R&D
 //
 // This library is free software; you can redistribute it and/or
 // modify it under the terms of the GNU Lesser General Public
 #include <pqComparativeVisPanel.h>
 #include <pqPipelineBrowserWidget.h>
 #include <pqProxyInformationWidget.h>
-#include <pqSettings.h>
 #include <pqDataInformationWidget.h>
 #include <pqPVAnimationWidget.h>
 #include <pqFindDataSelectionDisplayFrame.h>
-#include <pqMultiBlockInspectorPanel.h>
+#include <pqMultiBlockInspectorWidget.h>
 #include <pqProgressWidget.h>
 #include <pqProgressManager.h>
 #include <pqPropertiesPanel.h>
@@ -68,6 +67,8 @@
 #include <pqDeleteReaction.h>
 
 #include <vtkPVGeneralSettings.h>
+#include <vtkSMSettings.h>
+#include <vtkPVConfig.h>
 
 class ResizeHelper : public pqPVAnimationWidget
 {
@@ -121,7 +122,7 @@ void PVGUI_Module::setupDockWidgets()
 
   // PROPERTIES, DISPLAY and VIEW:
   // See ParaViewMainWindow.cxx - those three panels can be separated or grouped.
-  pqSettings *settings = pqApplicationCore::instance()->settings();
+  vtkSMSettings* settings = vtkSMSettings::GetInstance();
 
   //    Properties dock (previously called OBJECT_INSPECTOR)
   QDockWidget* propertiesDock = new QDockWidget( tr( "TTL_OBJECT_INSPECTOR" ), desk );
@@ -135,49 +136,61 @@ void PVGUI_Module::setupDockWidgets()
   //            hook delete to pqDeleteReaction.
   QAction* tempDeleteAction = new QAction(this);
   pqDeleteReaction* handler = new pqDeleteReaction(tempDeleteAction);
+#if PARAVIEW_VERSION_MAJOR==5 && PARAVIEW_VERSION_MINOR<9
   handler->connect(propertiesPanel, SIGNAL(deleteRequested(pqPipelineSource*)), SLOT(deleteSource(pqPipelineSource*)));
+#else
+  handler->connect(propertiesPanel, SIGNAL(deleteRequested(pqProxy*)), SLOT(deleteSource(pqProxy*)));
+#endif
   myDockWidgets[propertiesDock] = true;
   propertiesDock->hide();
 
+  int propertiesPanelMode = settings->GetSettingAsInt(
+      ".settings.GeneralSettings.PropertiesPanelMode", vtkPVGeneralSettings::ALL_IN_ONE);
+
   // Display dock
-  QDockWidget* displayPropertiesDock = new QDockWidget( tr( "TTL_DISPLAY" ), desk );
-  displayPropertiesDock->setObjectName("displayPropertiesDock");
-  displayPropertiesDock->setAllowedAreas( Qt::LeftDockWidgetArea|Qt::RightDockWidgetArea );
-  desk->addDockWidget( Qt::LeftDockWidgetArea, displayPropertiesDock );
-
-  pqPropertiesPanel* displayPropertiesPanel = new pqPropertiesPanel();
-  displayPropertiesPanel->setObjectName("displayPropertiesPanel");
-  displayPropertiesPanel->setProperty("panelMode", QVariant(2));  // probably to have only the Display part
-  displayPropertiesDock->setWidget(displayPropertiesPanel);
-  myDockWidgets[displayPropertiesDock] = false;
-  displayPropertiesDock->hide();
+  QDockWidget* displayPropertiesDock = 0;
+  if (propertiesPanelMode == vtkPVGeneralSettings::SEPARATE_DISPLAY_PROPERTIES ||
+      propertiesPanelMode == vtkPVGeneralSettings::ALL_SEPARATE )
+  {
+    displayPropertiesDock = new QDockWidget( tr( "TTL_DISPLAY" ), desk );
+    displayPropertiesDock->setObjectName("displayPropertiesDock");
+    displayPropertiesDock->setAllowedAreas( Qt::LeftDockWidgetArea|Qt::RightDockWidgetArea );
+    desk->addDockWidget( Qt::LeftDockWidgetArea, displayPropertiesDock );
+    
+    pqPropertiesPanel* displayPropertiesPanel = new pqPropertiesPanel();
+    displayPropertiesPanel->setObjectName("displayPropertiesPanel");
+    displayPropertiesPanel->setProperty("panelMode", QVariant(2));  // probably to have only the Display part
+    displayPropertiesDock->setWidget(displayPropertiesPanel);
+    myDockWidgets[displayPropertiesDock] = false;
+    displayPropertiesDock->hide();
+  }
 
   // View dock
-  QDockWidget* viewPropertiesDock = new QDockWidget( tr( "TTL_VIEW_PANEL" ), desk );
-  viewPropertiesDock->setObjectName("viewPropertiesDock");
-  viewPropertiesDock->setAllowedAreas( Qt::LeftDockWidgetArea|Qt::RightDockWidgetArea );
-  desk->addDockWidget( Qt::LeftDockWidgetArea, viewPropertiesDock );
-
-  pqPropertiesPanel* viewPropertiesPanel = new pqPropertiesPanel();
-  viewPropertiesPanel->setObjectName("viewPropertiesPanel");
-  viewPropertiesPanel->setProperty("panelMode", QVariant(4)); // probably to have only the View part
-  viewPropertiesDock->setWidget(viewPropertiesPanel);
-  myDockWidgets[viewPropertiesDock] = false;
-  viewPropertiesDock->hide();
-
-  // Taken from ParaViewMainWindow.cxx:
-  int propertiesPanelMode = settings->value(
-      "GeneralSettings.PropertiesPanelMode", vtkPVGeneralSettings::ALL_IN_ONE).toInt();
+  QDockWidget* viewPropertiesDock = 0;
+  if (propertiesPanelMode == vtkPVGeneralSettings::SEPARATE_VIEW_PROPERTIES ||
+      propertiesPanelMode == vtkPVGeneralSettings::ALL_SEPARATE )
+  {
+    viewPropertiesDock = new QDockWidget( tr( "TTL_VIEW_PANEL" ), desk );
+    viewPropertiesDock->setObjectName("viewPropertiesDock");
+    viewPropertiesDock->setAllowedAreas( Qt::LeftDockWidgetArea|Qt::RightDockWidgetArea );
+    desk->addDockWidget( Qt::LeftDockWidgetArea, viewPropertiesDock );
+    
+    pqPropertiesPanel* viewPropertiesPanel = new pqPropertiesPanel();
+    viewPropertiesPanel->setObjectName("viewPropertiesPanel");
+    viewPropertiesPanel->setProperty("panelMode", QVariant(4)); // probably to have only the View part
+    viewPropertiesDock->setWidget(viewPropertiesPanel);
+    myDockWidgets[viewPropertiesDock] = false;
+    viewPropertiesDock->hide();
+  }
+
   switch (propertiesPanelMode)
   {
     case vtkPVGeneralSettings::SEPARATE_DISPLAY_PROPERTIES:
-      viewPropertiesDock->hide();
       propertiesPanel->setPanelMode(
           pqPropertiesPanel::SOURCE_PROPERTIES|pqPropertiesPanel::VIEW_PROPERTIES);
       break;
 
     case vtkPVGeneralSettings::SEPARATE_VIEW_PROPERTIES:
-      displayPropertiesDock->hide();
       propertiesPanel->setPanelMode(
           pqPropertiesPanel::SOURCE_PROPERTIES|pqPropertiesPanel::DISPLAY_PROPERTIES);
       break;
@@ -190,8 +203,6 @@ void PVGUI_Module::setupDockWidgets()
     default:
       propertiesPanel->setPanelMode(
                 pqPropertiesPanel::SOURCE_PROPERTIES|pqPropertiesPanel::VIEW_PROPERTIES|pqPropertiesPanel::DISPLAY_PROPERTIES);
-      viewPropertiesDock->hide();
-      displayPropertiesDock->hide();
       break;
   }
 
@@ -220,8 +231,10 @@ void PVGUI_Module::setupDockWidgets()
 
   myDockWidgets[informationDock] = true;
 
+  if ( viewPropertiesDock )
   desk->tabifyDockWidget(propertiesDock, viewPropertiesDock);
-  desk->tabifyDockWidget(propertiesDock, displayPropertiesDock);
+  if ( displayPropertiesDock )
+    desk->tabifyDockWidget(propertiesDock, displayPropertiesDock);
   desk->tabifyDockWidget(propertiesDock, informationDock);
   propertiesDock->raise();
 
@@ -264,7 +277,7 @@ void PVGUI_Module::setupDockWidgets()
   QDockWidget* multiBlockInspectorPanelDock  = new QDockWidget( tr( "TTL_MUTLI_BLOCK_INSPECTOR" ), desk );
   multiBlockInspectorPanelDock->setObjectName("multiBlockInspectorPanelDock");
   desk->addDockWidget( Qt::LeftDockWidgetArea, multiBlockInspectorPanelDock );
-  pqMultiBlockInspectorPanel* mbi_panel = new pqMultiBlockInspectorPanel( multiBlockInspectorPanelDock );
+  pqMultiBlockInspectorWidget* mbi_panel = new pqMultiBlockInspectorWidget( multiBlockInspectorPanelDock );
   multiBlockInspectorPanelDock->setWidget(mbi_panel);
   myDockWidgets[multiBlockInspectorPanelDock] = false; // hidden by default