Salome HOME
sauve du 9 mai
[tools/eficas.git] / InterfaceQT4 / monChoixCommande.py
index a6ac039f7a473a9501e55247628bb4c1466d3d58..7c3fc4794db8899a08da275a5f8de5ceac4da7fa 100644 (file)
 # Modules Eficas
 
 from desChoixCommandes import Ui_ChoixCommandes
-from PyQt4  import *
-from PyQt4.QtCore import *
-from PyQt4.QtGui import *
-from PyQt4.QtCore import *
+from determine import monEnvQT5
+if monEnvQT5 :
+   from PyQt5.QtWidgets import QWidget, QAction ,QButtonGroup, QRadioButton, QLabel
+   from PyQt5.QtGui  import QIcon
+   from PyQt5.QtCore import QSize
+else :
+   from PyQt4.QtGui  import *
+   from PyQt4.QtCore import *
+
 from Extensions.i18n import tr
 import os
 
     
 # Import des panels
 
-class MonChoixCommande(Ui_ChoixCommandes,QtGui.QWidget):
+class MonChoixCommande(Ui_ChoixCommandes,QWidget):
   """
   """
   def __init__(self,node, jdc_item, editor):
-      QtGui.QWidget.__init__(self,None)
+      QWidget.__init__(self,None)
       self.setupUi(self)
-      #self.labelIcone.setText('<img src="/local00/home/A96028/Install_EficasV1/KarineEficas/InterfaceQT4/loopOff.png">');
+
+      self.repIcon=os.path.join( os.path.dirname(os.path.abspath(__file__)),'..','Editeur','icons')
+      iconeFile=os.path.join(self.repIcon,'lettreRblanc30.png')
+      icon = QIcon(iconeFile)
+      self.RBRegle.setIcon(icon)
+      self.RBRegle.setIconSize(QSize(21, 31))
 
       self.item = jdc_item
       self.node = node
@@ -44,23 +54,45 @@ class MonChoixCommande(Ui_ChoixCommandes,QtGui.QWidget):
       self.jdc  = self.item.object.get_jdc_root()
       debutTitre=self.editor.titre
       self.listeWidget=[]
+      self.dicoCmd={}
       if self.editor.fichier != None : 
           nouveauTitre=debutTitre+" "+str(os.path.basename(self.editor.fichier))
       else :
           nouveauTitre=debutTitre
       self.editor.appliEficas.setWindowTitle(nouveauTitre)
 
+      #print self.node.tree
 
-      self.connect(self.RBalpha,SIGNAL("clicked()"),self.afficheAlpha)
-      self.connect(self.RBGroupe,SIGNAL("clicked()"),self.afficheGroupe)
-      self.connect(self.RBOrdre,SIGNAL("clicked()"),self.afficheOrdre)
+      if monEnvQT5 :
+         self.RBalpha.clicked.connect(self.afficheAlpha)
+         self.RBGroupe.clicked.connect(self.afficheGroupe)
+         self.RBOrdre.clicked.connect(self.afficheOrdre)
+         self.RBClear.clicked.connect(self.clearFiltre)
+         self.RBCasse.toggled.connect(self.ajouteRadioButtons)
+         self.LEFiltre.returnPressed.connect(self.ajouteRadioButtons)
+         self.LEFiltre.textChanged.connect(self.ajouteRadioButtons)
+      else :
+         self.connect(self.RBalpha,SIGNAL("clicked()"),self.afficheAlpha)
+         self.connect(self.RBGroupe,SIGNAL("clicked()"),self.afficheGroupe)
+         self.connect(self.RBOrdre,SIGNAL("clicked()"),self.afficheOrdre)
+         self.connect(self.RBClear,SIGNAL("clicked()"),self.clearFiltre)
+         self.connect(self.RBCasse,SIGNAL("toggled(bool)"),self.ajouteRadioButtons)
+         self.connect(self.LEFiltre,SIGNAL("returnPressed()"),self.ajouteRadioButtons)
+      if self.node.tree.item.get_regles() == () :
+         self.RBRegle.close()
+         self.labelRegle.close()
+      else : 
+        if monEnvQT5 : self.RBRegle.clicked.connect(self.afficheRegle)
+        else         : self.connect(self.RBRegle,SIGNAL("clicked()"),self.afficheRegle)
 
       if self.editor.Ordre_Des_Commandes == None : self.RBOrdre.close()
 
        
-      self.editor.labelCommentaire.setText("")
+      #self.editor.labelCommentaire.setText("")
+      if self.editor.widgetOptionnel!= None : 
+         self.editor.fermeOptionnel()
+         self.editor.widgetOptionnel=None
       self.name=None
-      self.connect(self.LEFiltre,SIGNAL("returnPressed()"),self.AjouteRadioButton)
 
       self.affiche_alpha=0
       self.affiche_groupe=0
@@ -77,24 +109,28 @@ class MonChoixCommande(Ui_ChoixCommandes,QtGui.QWidget):
          self.affiche_ordre==1;  
          self.RBOrdre.setChecked(True);  
          self.afficheOrdre()
+      if self.editor.code == "Adao" : self.frameAffichage.close()
+
+  def afficheRegle(self):
+      self.node.tree.AppelleBuildLBRegles()
 
   def afficheAlpha(self):
       self.affiche_alpha=1
       self.affiche_groupe=0
       self.affiche_ordre=0
-      self.AjouteRadioButton()
+      self.ajouteRadioButtons()
 
   def afficheGroupe(self):
       self.affiche_alpha=0
       self.affiche_groupe=1
       self.affiche_ordre=0
-      self.AjouteRadioButton()
+      self.ajouteRadioButtons()
 
   def afficheOrdre(self):
       self.affiche_alpha=0
       self.affiche_groupe=0
       self.affiche_ordre=1
-      self.AjouteRadioButton()
+      self.ajouteRadioButtons()
 
   def mouseDoubleClickEvent(self,event):
       nodeCourrant=self.node.tree.currentItem()
@@ -103,6 +139,8 @@ class MonChoixCommande(Ui_ChoixCommandes,QtGui.QWidget):
          plier=self.editor.afficheCommandesPliees
          if nodeCourrant==self.node : nouveau=self.node.append_child(self.name,'first',plier)
          else : nouveau=nodeCourrant.append_brother(self.name,plier=plier)
+      else :
+         nouveau = 0
       if nouveau == 0 : return # on n a pas insere le noeud
       nouveau.setDeplie()
       #if self.editor.afficheApresInsert==True : nouveau.plieToutEtReaffiche()
@@ -119,8 +157,9 @@ class MonChoixCommande(Ui_ChoixCommandes,QtGui.QWidget):
       event.accept()
       
 
-  def CreeListeCommande(self,filtre):
+  def creeListeCommande(self,filtre):
       listeGroupes,dictGroupes=self.jdc.get_groups()
+      sensibleALaCasse=self.RBCasse.isChecked()
       if "CACHE" in dictGroupes.keys():
          aExclure=dictGroupes["CACHE"]
       else:
@@ -128,11 +167,12 @@ class MonChoixCommande(Ui_ChoixCommandes,QtGui.QWidget):
       listeACreer=[]
       for l in self.jdc.get_liste_cmd():
          if l not in aExclure : 
-            if filtre != None and not filtre in l : continue
+            if sensibleALaCasse and (filtre != None and not filtre in l) : continue
+            if (not sensibleALaCasse) and filtre != None and (not filtre in l) and (not filtre.upper() in l) : continue
             listeACreer.append(l)
       return listeACreer
 
-  def AjouteRadioButton(self):
+  def ajouteRadioButtons(self):
       filtre=str(self.LEFiltre.text())
       if filtre==str("") : filtre=None
       if hasattr(self,'buttonGroup') :
@@ -145,38 +185,51 @@ class MonChoixCommande(Ui_ChoixCommandes,QtGui.QWidget):
          w.close()
       self.listeWidget=[]
       if self.affiche_alpha==1 :
-         liste=self.CreeListeCommande(filtre)
+         liste=self.creeListeCommande(filtre)
          for cmd in liste :
+           self.dicoCmd[tr(cmd)]=cmd
            rbcmd=(QRadioButton(tr(cmd)))
            self.buttonGroup.addButton(rbcmd)
            self.commandesLayout.addWidget(rbcmd)
            rbcmd.mouseDoubleClickEvent=self.mouseDoubleClickEvent
-           self.connect(self.buttonGroup, SIGNAL("buttonClicked(QAbstractButton*)"),self.rbClique) 
+           if monEnvQT5:
+              self.buttonGroup.buttonClicked.connect(self.rbClique) 
+           else :
+              self.connect(self.buttonGroup, SIGNAL("buttonClicked(QAbstractButton*)"),self.rbClique) 
       elif  self.affiche_groupe==1 :
          listeGroupes,dictGroupes=self.jdc.get_groups()
          for grp in listeGroupes:
            if grp == "CACHE" : continue
            label=QLabel(self)
-           text=QString.fromUtf8('<html><head/><body><p><span style=\" font-weight:600;\">Groupe : '+tr(grp)+'</span></p></body></html>')
+           if monEnvQT5 :
+              text=tr('<html><head/><body><p><span style=\" font-weight:600;\">Groupe : '+tr(grp)+'</span></p></body></html>')
+           else :
+              text=QString.fromUtf8('<html><head/><body><p><span style=\" font-weight:600;\">Groupe : '+tr(grp)+'</span></p></body></html>')
            label.setText(text)
            self.listeWidget.append(label)
            aAjouter=1
+           sensibleALaCasse=self.RBCasse.isChecked()
            for cmd in  dictGroupes[grp]:
-              if filtre != None and not filtre in cmd : continue
+              if sensibleALaCasse and (filtre != None and not filtre in cmd) : continue
+              if (not sensibleALaCasse) and filtre != None and (not filtre in cmd) and (not filtre.upper() in cmd) : continue
               if aAjouter == 1 :
                  self.commandesLayout.addWidget(label)
                  aAjouter=0
+              self.dicoCmd[tr(cmd)]=cmd
               rbcmd=(QRadioButton(tr(cmd)))
               self.buttonGroup.addButton(rbcmd)
               self.commandesLayout.addWidget(rbcmd)
               rbcmd.mouseDoubleClickEvent=self.mouseDoubleClickEvent
-              self.connect(self.buttonGroup, SIGNAL("buttonClicked(QAbstractButton*)"),self.rbClique)
+              if monEnvQT5:
+                 self.buttonGroup.buttonClicked.connect(self.rbClique) 
+              else :
+                  self.connect(self.buttonGroup, SIGNAL("buttonClicked(QAbstractButton*)"),self.rbClique)
            label2=QLabel(self)
            label2.setText(" ")
            self.listeWidget.append(label2)
            self.commandesLayout.addWidget(label2)
       elif  self.affiche_ordre==1 :
-         listeFiltre=self.CreeListeCommande(filtre)
+         listeFiltre=self.creeListeCommande(filtre)
          liste=[]
          if self.editor.Ordre_Des_Commandes == None : Ordre_Des_Commandes=listeFiltre
          else : Ordre_Des_Commandes=self.editor.Ordre_Des_Commandes
@@ -184,19 +237,24 @@ class MonChoixCommande(Ui_ChoixCommandes,QtGui.QWidget):
             if cmd in listeFiltre :
                  liste.append(cmd)
          for cmd in liste :
+           self.dicoCmd[tr(cmd)]=cmd
            rbcmd=(QRadioButton(tr(cmd)))
            self.buttonGroup.addButton(rbcmd)
            self.commandesLayout.addWidget(rbcmd)
            rbcmd.mouseDoubleClickEvent=self.mouseDoubleClickEvent
-           self.connect(self.buttonGroup, SIGNAL("buttonClicked(QAbstractButton*)"),self.rbClique) 
+           if monEnvQT5:
+              self.buttonGroup.buttonClicked.connect(self.rbClique) 
+           else :
+              self.connect(self.buttonGroup, SIGNAL("buttonClicked(QAbstractButton*)"),self.rbClique)
 
      
-  def LEfiltreReturnPressed(self):
-      self.AjouteRadioButton(filtre)
 
+  def clearFiltre(self):
+      self.LEFiltre.setText("")
+      self.ajouteRadioButtons()
 
   def rbClique(self,id):
-      self.name=str(id.text().toLatin1())
+      self.name=self.dicoCmd[str(id.text())]
       definitionEtape=getattr(self.jdc.cata[0],self.name)
       commentaire=getattr(definitionEtape,self.jdc.lang)
       try :
@@ -206,7 +264,7 @@ class MonChoixCommande(Ui_ChoixCommandes,QtGui.QWidget):
            commentaire=getattr(definitionEtape,"ang")
         except :
            commentaire=""
-      self.editor.labelCommentaire.setText(commentaire)
+      self.editor.affiche_commentaire(commentaire)