Salome HOME
Merge V9 dans Master
[tools/eficas.git] / InterfaceQT4 / monWidgetRadioButton.py
index cff2bbc226888a28bc82549e899c0d560c7182dd..129046be58d590d7262148b4142db5f957f57035 100644 (file)
@@ -1,5 +1,5 @@
 # -*- coding: utf-8 -*-
-# Copyright (C) 2007-2013   EDF R&D
+# Copyright (C) 2007-2017   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
 # See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
 #
 # Modules Python
-import string,types,os
+from __future__ import absolute_import
+from __future__ import print_function
+try :
+   from builtins import str
+except : pass
+
+import types,os
+
+from PyQt5.QtCore     import  Qt
+from PyQt5.QtWidgets  import  QWidget
 
 # Modules Eficas
-from PyQt4.QtGui import *
-from PyQt4.QtCore import *
+
 from Extensions.i18n import tr
 
-from feuille               import Feuille
+from .feuille               import Feuille
 from desWidgetRadioButton  import Ui_WidgetRadioButton 
-from politiquesValidation  import PolitiqueUnique
-from qtSaisie              import SaisieValeur
+from .politiquesValidation  import PolitiqueUnique
+from .qtSaisie              import SaisieValeur
 
 
 class MonWidgetRadioButtonCommun (Feuille):
@@ -45,11 +53,12 @@ class MonWidgetRadioButtonCommun (Feuille):
 
 
   def setValeursApresBouton(self):
-      if self.objSimp.get_valeur()==None : return
-      valeur=self.objSimp.get_valeur()
-      if not(type(valeur) in types.StringTypes) : valeur=str(valeur)
+      if self.objSimp.getValeur()==None : return
+      valeur=self.objSimp.getValeur()
+      if not(isinstance(valeur, str)) : valeur = str(valeur)
       try :
         self.dict_bouton[valeur].setChecked(True)
+        self.dict_bouton[valeur].setFocus(True)
       except :
         pass
 
@@ -58,16 +67,16 @@ class MonWidgetRadioButtonCommun (Feuille):
       i=1
       j=len(self.maListeDeValeur)
       if j > self.maxI : 
-         print "poumbadaboum"
+         print ("poumbadaboum")
          return
       while i < j+1 :
          nomBouton="radioButton_"+str(i)
          bouton=getattr(self,nomBouton)
          valeur=self.maListeDeValeur[i-1]
-         if not(type(valeur) in types.StringTypes) : valeur=str(valeur)
-         bouton.setText(valeur)
+         if not(isinstance(valeur, str)) : valeur = str(valeur)
+         bouton.setText(tr(valeur))
          self.dict_bouton[valeur]=bouton
-         self.connect(bouton,SIGNAL("clicked()"),self.boutonclic)
+         bouton.clicked.connect(self.boutonclic)
          bouton.keyPressEvent=self.keyPressEvent
          setattr(self,nomBouton,bouton)
          i=i+1
@@ -78,22 +87,23 @@ class MonWidgetRadioButtonCommun (Feuille):
          i=i+1
 
   def boutonclic(self):
-      for valeur in self.dict_bouton.keys():
+      for valeur in self.dict_bouton:
           if self.dict_bouton[valeur].isChecked():
              #print "dans boutonclic is checked", valeur, type(valeur)
-             SaisieValeur.LEValeurPressed(self,valeur)
+             SaisieValeur.LEvaleurPressed(self,valeur)
       self.reaffiche()
 
 
   def keyPressEvent(self, event):
     if event.key() == Qt.Key_Right : self.selectSuivant(); return
     if event.key() == Qt.Key_Left  : self.selectPrecedent(); return
+    if event.key() == Qt.Key_Return or event.key() == Qt.Key_Space : self.checkFocused(); return
     QWidget.keyPressEvent(self,event)
 
   def selectSuivant(self):
       aLeFocus=self.focusWidget()
       nom=aLeFocus.objectName()[12:]
-      i=nom.toInt()[0]+1
+      i=int(nom)+1
       if i ==  len(self.maListeDeValeur) +1 : i=1
       nomBouton="radioButton_"+str(i)
       courant=getattr(self,nomBouton)
@@ -102,17 +112,30 @@ class MonWidgetRadioButtonCommun (Feuille):
   def selectPrecedent(self):
       aLeFocus=self.focusWidget()
       nom=aLeFocus.objectName()[12:]
-      i=nom.toInt()[0]-1
+      i=int(nom)-1
       if i == 0 : i= len(self.maListeDeValeur)  
       nomBouton="radioButton_"+str(i)
       courant=getattr(self,nomBouton)
       courant.setFocus(True)
 
+  def checkFocused(self):
+      aLeFocus=self.focusWidget()
+      nom=aLeFocus.objectName()[12:]
+      i=int(nom)
+      if i > 0 and i <= len(self.maListeDeValeur):
+        nomBouton="radioButton_"+str(i)
+        courant=getattr(self,nomBouton)
+        if not courant.isChecked():
+          courant.setChecked(True)
+          self.boutonclic()
+
 
 class MonWidgetRadioButton (Ui_WidgetRadioButton,MonWidgetRadioButtonCommun):
   def __init__(self,node,monSimpDef,nom,objSimp,parentQt,commande):
         #print "MonWidgetRadioButton ", self
-        self.maListeDeValeur=monSimpDef.into
+        if type(monSimpDef.into) ==types.FunctionType : self.maListeDeValeur=monSimpDef.into()
+        else : self.maListeDeValeur=monSimpDef.into
+
         MonWidgetRadioButtonCommun.__init__(self,node,monSimpDef,nom,objSimp,parentQt,commande)
         
   def setMaxI(self):
@@ -123,7 +146,7 @@ class MonWidgetRadioButtonSD (Ui_WidgetRadioButton,MonWidgetRadioButtonCommun):
 
   def __init__(self,node,monSimpDef,nom,objSimp,parentQt,commande):
         #print "dans le init de MonWidgetRadioButtonSD",self
-        self.maListeDeValeur=node.item.get_sd_avant_du_bon_type()
+        self.maListeDeValeur=node.item.getSdAvantDuBonType()
         MonWidgetRadioButtonCommun.__init__(self,node,monSimpDef,nom,objSimp,parentQt,commande)
 
   def setMaxI(self):