Salome HOME
Plie/Deplie MT
[tools/eficas.git] / InterfaceQT4 / monWidgetCommande.py
index 0cb3b8eeeecd4c0407cf7dc868b0e9ccf1b1b89b..ad2adae3e5ed80de2afd2a153d15cdd962fec443 100644 (file)
 #
 # Modules Python
 # Modules Eficas
+from __future__ import absolute_import
+try :
+   from builtins import str
+except : pass
+
+import types
 
 from desWidgetCommande import Ui_WidgetCommande
-from groupe import Groupe
-from gereIcones import FacultatifOuOptionnel
-from determine import monEnvQT5
+from .groupe import Groupe
+from .gereIcones import FacultatifOuOptionnel
+
+from PyQt5.QtWidgets  import QApplication, QWidget, QSpacerItem, QSizePolicy
+from PyQt5.QtGui import QFont, QIcon
+from PyQt5.QtCore import QTimer
+from PyQt5.QtCore import Qt
 
-if monEnvQT5:
-   from PyQt5.QtWidgets  import QApplication, QWidget, QSpacerItem, QSizePolicy
-   from PyQt5.QtGui import QFont, QIcon
-   from PyQt5.QtCore import QTimer
-else :
-   from PyQt4.QtGui import *
-   from PyQt4.QtCore import *
 
 
 from Extensions.i18n import tr
 import Accas 
 import os
-import string
 
     
 # Import des panels
@@ -59,7 +61,9 @@ class MonWidgetCommande(Ui_WidgetCommande,Groupe):
         self.frameAffichage.resize(self.frameAffichage.width(),50)
       
       #if (etape.get_type_produit()==None): self.LENom.close()
+      #test,mess = self.node.item.nomme_sd('ee')
       if not(hasattr(etape.definition,'sd_prod')) or (etape.definition.sd_prod==None): self.LENom.close()
+      elif (hasattr(etape.definition,'sd_prod') and type(etape.definition.sd_prod)== types.FunctionType):self.LENom.close()
       elif (hasattr(etape, 'sdnom')) and etape.sdnom != "sansnom" and etape.sdnom != None: self.LENom.setText(etape.sdnom)
       else : self.LENom.setText("")
 
@@ -68,30 +72,20 @@ class MonWidgetCommande(Ui_WidgetCommande,Groupe):
       self.setFont(maPolice)
       self.labelNomCommande.setText(tr(self.obj.nom))
 
-      self.commandesLayout.addStretch()
-      self.commandesLayout.focusInEvent=self.focusInEvent
-      self.scrollAreaCommandes.focusInEvent=self.focusInEvent
 
-     
-      if self.editor.closeFrameRechercheCommande==True : self.closeAutreCommande()
+      if self.editor.closeAutreCommande==True  : self.closeAutreCommande()
       else :
-        if monEnvQT5 :
-         try :
+        try :
            self.bCatalogue.clicked.connect(self.afficheCatalogue)
            self.bAvant.clicked.connect(self.afficheAvant)
            self.bApres.clicked.connect(self.afficheApres)
-         except :
+        except :
            pass
-         self.LENom.returnPressed.connect(self.nomChange)
-        else : 
-         try :
-            self.connect(self.bCatalogue,SIGNAL("clicked()"), self.afficheCatalogue)
-            self.connect(self.bAvant,SIGNAL("clicked()"), self.afficheAvant)
-            self.connect(self.bApres,SIGNAL("clicked()"), self.afficheApres)
-         except :
-            pass
-         self.connect(self.LENom,SIGNAL("returnPressed()"),self.nomChange)
+        self.LENom.returnPressed.connect(self.nomChange)
    
+      if self.editor.code in ['Adao','ADAO'] and self.editor.closeFrameRechercheCommande==True  : 
+                      self.frameAffichage.close()
+
       if self.editor.code in ['CARMELCND',] : self.closeAutreCommande()
       self.racine=self.node.tree.racine
       if self.node.item.GetIconName() == "ast-red-square" : self.LENom.setDisabled(True)
@@ -103,21 +97,22 @@ class MonWidgetCommande(Ui_WidgetCommande,Groupe):
          self.RBPoubelle.close() # JDC Fige
          return                  # Pas de MC Optionnels pour Carmel
 
-      from monWidgetOptionnel import MonWidgetOptionnel
+      from .monWidgetOptionnel import MonWidgetOptionnel
       if self.editor.widgetOptionnel!= None : 
         self.monOptionnel=self.editor.widgetOptionnel
       else :
-        self.monOptionnel=MonWidgetOptionnel(self)
-        self.editor.widgetOptionnel=self.monOptionnel
         self.editor.inhibeSplitter=1
+        self.monOptionnel=MonWidgetOptionnel(self.editor)
+        self.editor.widgetOptionnel=self.monOptionnel
         self.editor.splitter.addWidget(self.monOptionnel)
-        self.editor.inhibeSplitter=0
         self.editor.ajoutOptionnel()
+        self.editor.inhibeSplitter=0
       self.afficheOptionnel()
+      #self.editor.restoreSplitterSizes()
 
-      self.editor.restoreSplitterSizes()
       #print "fin init de widget Commande"
       
+
   def closeAutreCommande(self):
       self.bCatalogue.close()
       self.bAvant.close()
@@ -186,13 +181,18 @@ class MonWidgetCommande(Ui_WidgetCommande,Groupe):
          i=i+1
       # si on boucle on perd l'ordre
  
+  def  afficheNieme(self,n):
+      #print ('ds afficheNieme')
+      self.listeAffichageWidget[n].setFocus(7)
+
   def  afficheSuivant(self,f):
+      #print ('ds afficheSuivant')
       try :
         i=self.listeAffichageWidget.index(f) 
         next=i+1
       except :
         next=1
-      if (next==len(self.listeAffichageWidget) -1 ): next =0
+      if (next==len(self.listeAffichageWidget) ): next =0
       #self.f=next
       #QTimer.singleShot(1, self.rendVisible)
       try :
@@ -202,14 +202,14 @@ class MonWidgetCommande(Ui_WidgetCommande,Groupe):
 
   def nomChange(self):
       nom = str(self.LENom.text())
-      nom = string.strip(nom)
+      nom = nom.strip()
       if nom == '' : return                  # si pas de nom, on ressort sans rien faire
       test,mess = self.node.item.nomme_sd(nom)
       self.editor.affiche_commentaire(mess)
 
       #Notation scientifique
       if test :
-        from politiquesValidation import Validation
+        from .politiquesValidation import Validation
         validation=Validation(self.node,self.editor)
         validation.AjoutDsDictReelEtape()
 
@@ -224,10 +224,10 @@ class MonWidgetCommande(Ui_WidgetCommande,Groupe):
       self.monGroupe=self.monOptionnel.afficheOptionnel(liste,self)
       
 
-  #def focusInEvent(self,event):
+  def focusInEvent(self,event):
       #print "je mets a jour dans focusInEvent de monWidget Commande "
-  #    if self.editor.code == "CARMELCND" : return #Pas de MC Optionnels pour Carmel
-  #    self.afficheOptionnel()
+      if self.editor.code == "CARMELCND" : return #Pas de MC Optionnels pour Carmel
+      self.afficheOptionnel()
 
 
   def reaffiche(self,nodeAVoir=None):
@@ -248,6 +248,18 @@ class MonWidgetCommande(Ui_WidgetCommande,Groupe):
       else : self.recentre()
       self.inhibeExpand=False
 
+  def reafficheSeulement(self,nodeAReafficher,index):
+      #print ('ds reafficheSeulement', nodeAReafficher)
+      parentNodeAReafficher=nodeAReafficher.parentQt
+      index=parentNodeAReafficher.commandesLayout.indexOf(nodeAReafficher)
+      oldFenetre=nodeAReafficher.node.fenetre
+      newWidget=nodeAReafficher.node.getPanelGroupe(parentNodeAReafficher,self,index)
+      nodeAReafficher.node.fenetre=newWidget
+      oldFenetre.setParent(None)
+      oldFenetre.close()
+      oldFenetre.deleteLater()
+      #print ("fin pour " , self.node.item.nom)
+
 
   def recentre(self):
       QApplication.processEvents()